共计 3307 个字符,预计需要花费 9 分钟才能阅读完成。
nginx(静态页面,图片分离)
#vi /usr/local/nginx/conf/nginx.conf
user nginx nginx;
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
upstream webservs {
server 172.16.100.6 weight=1;
server 172.16.100.7 weight=1;
}
server {
listen 8082;
server_name localhost;
index index.html index.htm index.php;
rewrite ^/$ /zabbix/index.php permanent;
location / {
proxy_pass webservs;
proxy_set_header X-Real-IP $remote_addr;
}
location /zabbix {
root /var/www;
fastcgi_pass 127.0.0.1:8000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
#配置 Nginx 动静分离,定义的静态页面直接从 zabbix 发布目录读取(root /opt/nginx-1.4.7/html/resources;)。
location ~* ^/zabbix/.+\.(ico|gif|jpg|jpeg|html|htm|png|css|bmp|js|svg)$ {
root /var/www;
#expires 定义用户浏览器缓存的时间为 7 天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力
expires 7d;
}
#配置静态图片页面
location ~ .*\.(gif|jpg|jpeg|png)$ {
expires 24h; #设置浏览器过期时间
root /home/picimages/; #指定图片存放路径
access_log /usr/local/nginx/logs/picimages.log; #图片日志路径
proxy_store on; #开启缓存机制
proxy_store_access user:rw group:rw all:rw; #缓存读写规则
proxy_temp_path /home/picimages/; #代理临时路径
proxy_redirect off;
proxy_set_header Host 127.0.0.1;
client_max_body_size 10m;
client_body_buffer_size 1280k;
proxy_connect_timeout 900;
proxy_send_timeout 900;
proxy_read_timeout 900;
proxy_buffer_size 40k;
proxy_buffers 40 320k;
proxy_busy_buffers_size 640k;
proxy_temp_file_write_size 640k;
if (!-e $request_filename) ## 正则表达式,匹配缓存目录中的文件与源文件是否存在, 当访问的文件和目录不存在时,重定向到某个网站地址或文件
proxy_pass http://127.0.0.1:8082; #代理访问地址
}
}
location /citizen {
proxy_pass http://172.28.3.103:9081;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host:$server_port;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
详解说明:
其中配置静态图片页面
proxy_store on 启用缓存到本地的功能,
proxy_temp_path 指定缓存在哪个目录下,如:proxy_temp_path /var/nginx_cache;
在经过上一步配置之后,虽然文件被缓存到了本地磁盘上,但每次请求仍会向远端拉取文件,为了避免去远端拉取文件,还必须增加:
if (!-e $request_filename) {
proxy_pass http://127.0.0.1:8082;
}
即改成有条件地去执行 proxy_pass,这个条件就是当请求的文件在本地的 proxy_temp_path 指定的目录下不存在时,再向后端拉取。
$request_filename 变量指的就是请求的资源路径
正则表达式:
= 开头表示精确匹配
^~ 开头表示 uri 以某个常规字符串开头,不是正则匹配
~ 开头表示区分大小写的正则匹配;
~* 开头表示不区分大小写的正则匹配
/ 通用匹配, 如果没有其它匹配, 任何请求都会匹配到
flag 标志位
last : 相当于 Apache 的[L] 标记,表示完成 rewrite
break : 停止执行当前虚拟主机的后续 rewrite 指令集
redirect : 返回 302 临时重定向,地址栏会显示跳转后的地址
permanent : 返回 301 永久重定向,地址栏会显示跳转后的地址
因为 301 和 302 不能简单的只返回状态码,还必须有重定向的 URL,这就是 return 指令无法返回 301,302 的原因了。这里 last 和 break 区别有点难以理解:
last 一般写在 server 和 if 中,而 break 一般使用在 location 中
last 不终止重写后的 url 匹配,即新的 url 会再从 server 走一遍匹配流程,而 break 终止重写后的匹配
break 和 last 都能组织继续执行后面的 rewrite 指令
if 指令与全局变量
if 判断指令
语法为 if(condition){…},对给定的条件 condition 进行判断。如果为真,大括号内的 rewrite 指令将被执行,if 条件 (conditon) 可以是如下任何内容:
当表达式只是一个变量时,如果值为空或任何以 0 开头的字符串都会当做 false
直接比较变量和内容时,使用 = 或!=
~ 正则表达式匹配,~* 不区分大小写的匹配,!~ 区分大小写的不匹配
- f 和!- f 用来判断是否存在文件
- d 和!- d 用来判断是否存在目录
- e 和!- e 用来判断是否存在文件或目录
- x 和!- x 用来判断文件是否可执行
常用正则
.:匹配除换行符以外的任意字符
?:重复 0 次或 1 次
+:重复 1 次或更多次
*:重复 0 次或更多次
\d:匹配数字
^:匹配字符串的开始
$:匹配字符串的介绍
{n}:重复 n 次
{n,}:重复 n 次或更多次
[c]:匹配单个字符 c
[a-z]:匹配 a - z 小写字母的任意一个
小括号 () 之间匹配的内容,可以在后面通过 $1 来引用,$2 表示的是前面第二个 () 里的内容。正则里面容易让人困惑的是 \ 转义特殊字符。
: