1.location语法规则
location [=|~|~*|^~] /uri/ {
…
}
比如:
1.1= 开头表示精确匹配
location = /storage/ {
echo "match success!";
}
1.2 ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。
匹配 http://ip address/storage/XXX/XXX……
http://ip address/storage/ /XXX……(/storage/之后可以包含空格)
location ^~ /storage/ {
echo 'storage巴拉巴拉、、、、、'';
}
1.3 ~ 开头表示区分大小写的正则匹配。
http://ip address/xxx.gif | xx.png ……
匹配成功后 会在html目录下查找xxx.gif | xx.png 文件
location ~ \.(gif|jpg|png|js|css)$ {
//设置存储的路径
root html;
}
1.4 ~* 开头表示不区分大小写的正则匹配。(大小写通杀)
http://ip address/xxx.PNG
匹配html下xxx.PNG文件
location ~* \.png$ {
root html;
}
1.5 !~ 和!~* 分别为区分大小写不匹配及不区分大小写不匹配的正则。
location ~* \.png$ {
echo 'xxx';
}
location !~ \.xhtml$ {
echo 'xxxxx';
}
1.6 / 通用匹配,任何请求都会匹配到。
location / {
echo '任何规则都会匹配到!';
}
2.实际使用中,通常至少有三个匹配规则定义,如下:
#直接匹配网站根,通过域名访问网站首页比较频繁,使用这个会加速处理,官网如是说。
#这里是直接转发给后端应用服务器了,也可以是一个静态首页
# 第一个必选规则
location = / {
proxy_pass http://localhost:8080/index
}
# 第二个必选规则是处理静态文件请求,这是nginx作为http服务器的强项
# 有两种配置模式,目录匹配或后缀匹配,任选其一或搭配使用
location ^~ /static/ {
root /webroot/static/;
}
location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
root /webroot/res/;
}
#第三个规则就是通用规则,用来转发动态请求到后端应用服务器
#非静态文件请求就默认是动态请求,自己根据实际把握
#毕竟目前的一些框架的流行,带.php,.jsp后缀的情况很少了
location / {
proxy_pass http://localhost:8080/
}
3.匹配顺序:
首先匹配 =,其次匹配^~, 其次是按文件中顺序的正则匹配,
最后是交给 / 通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。