目录
1. Location语法规则
2. location如何发挥作用
3. 精确匹配
4. 前缀匹配
5. 正则匹配
6. 优先级
7. 匹配规则示例
8. 实际常用规则
1. Location语法规则
语法规则: location [ / | = | ~ | ~* | ^~ ] /uri/ { … }
首先匹配 =,接着匹配^~,其次是按文件中顺序的正则匹配,最后是交给 /通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。
符号 | 含义 |
= | = 开头表示精确匹配,如果这个查询匹配,那么将停止搜索并立即处理此请求。 |
^~ | ^~开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格) |
~ | ~ 开头表示区分大小写的正则匹配 |
~* | ~* 开头表示不区分大小写的正则匹配 |
!~和!~* | !~和!~*分别为区分大小写不匹配及不区分大小写不匹配的正则 |
/ | 用户所使用的代理(一般为浏览器) |
$http_x_forwarded_for | 可以记录客户端IP,通过代理服务器来记录客户端的ip地址 |
$http_referer | 可以记录用户是从哪个链接访问过来的
|
2. location如何发挥作用
3. 精确匹配
语法示例:
location = /static/img/file.jpg {
...
}
4. 前缀匹配
1、普通前缀匹配
语法示例:
location /static/img/ {
...
}
2、优先前缀匹配
语法示例:
location ^~/static/img/ {
...
}
5. 正则匹配
1、区分大小写
语法示例:
location ~ /static/img/.*\\.jpg$ {
...
}
2、不区分大小写
语法示例:
location ~* /static/img/.*\\.jpg$ {
...
}
3、区分大小写取反
语法示例:
location !~ /static/img/.*\\.jpg$ {
...
}
4、不区分大小写取反
语法示例:
location !~* /static/img/.*\\.jpg$ {
...
}
6. 优先级
对于请求: http://example.com/static/img/logo.jpg
1、如果命中精确匹配,例如:
location = /static/img/logo.jpg {
}
则优先精确匹配,并终止匹配。
2、如果命中多个前缀匹配,例如:
location /static/ {
}
location /static/img/ {
}
则记住最长的前缀匹配,即上例中的 /static/img/,并继续匹配
3、如果最长的前缀匹配是优先前缀匹配,即:
location /static/ {
}
location ^~ /static/img/ {
}
则命中此最长的优先前缀匹配,并终止匹配
4、否则,如果命中多个正则匹配,即:
location /static/ {
}
location /static/img/ {
}
location ~* /static/ {
}
location ~* /static/img/ {
}
则忘记上述 2 中的最长前缀匹配,使用第一个命中的正则匹配,即上例中的 location ~* /static/ ,并终止匹配(命中多个正则匹配,优先使用配置文件中出现次序的第一个)
5、否则,命中上述 2 中记住的最长前缀匹配
7. 匹配规则示例
location = / {
#规则A
}
location = /login {
#规则B
}
location ^~ /static/ {
#规则C
}
location ~ \.(gif|jpg|png|js|css)$ {
#规则D
}
location ~* \.png$ {
#规则E
}
location !~ \.xhtml$ {
#规则F
}
location !~* \.xhtml$ {
#规则G
}
location / {
#规则H
}
那么产生的效果如下:
1. 访问根目录/,比如http://localhost/将匹配规则A
2. 访问 http://localhost/login 将匹配规则B,http://localhost/register则匹配规则H
3. 访问 http://localhost/static/a.html 将匹配规则C
4. 访问 http://localhost/a.gif,http://localhost/b.jpg 将匹配规则D和规则E,但是规则D顺序优先,规则E不起作用,而http://localhost/static/c.png则优先匹配到规则C
5. 访问 http://localhost/a.PNG 则匹配规则E,而不会匹配规则D,因为规则E不区分大小写。
6. 访问 http://localhost/a.xhtml 不会匹配规则F和规则G,http://localhost/a.XHTML不会匹配规则G,因为不区分大小写。规则F,规则G属于排除法,符合匹配规则但是不会匹配到,所以想想看实际应用中哪里会用到。
7. 访问 http://localhost/category/id/1111 则最终匹配到规则H,因为以上规则都不匹配,这个时候应该是nginx转发请求给后端应用服务器,比如FastCGI(PHP),tomcat(jsp),nginx作为方向代理服务器存在。
8. 实际常用规则
#直接匹配网站根,通过域名访问网站首页比较频繁,使用这个会加速处理。
#这里是直接转发给后端应用服务器了,也可以是一个静态首页
1. 第一个必选规则
location = / {
proxy_pass http://tomcat:8080/index
}
2. 第二个必选规则是处理静态文件请求,这是nginx作为http服务器的强项
# 有两种配置模式,目录匹配或后缀匹配,任选其一或搭配使用
location ^~ /static/ {
# 请求/static/a.txt 将被映射到实际目录文件:/webroot/res/static/a.txt
root /webroot/res/;
}
location ~* \.(gif|jpg|jpeg|png|css|js|ico)${
root /webroot/res/;
3. 第三个规则就是通用规则,用来转发动态请求到后端应用服务器
#非静态文件请求就默认是动态请求,自己根据实际把握
#毕竟目前的一些框架的流行,带.php,.jsp后缀的情况很少了
location / {
proxy_pass http://tomcat:8080/
}