目录
1. Location语法规则
2. location如何发挥作用
3. 精确匹配
4. 前缀匹配
5. 正则匹配
6. 优先级
7. 匹配规则示例
8. 实际常用规则
语法规则: location [ / | = | ~ | ~* | ^~ ] /uri/ { … }
首先匹配 =,接着匹配^~,其次是按文件中顺序的正则匹配,最后是交给 /通用匹配。当有匹配成功时候,停止匹配,按当前匹配规则处理请求。
符号
含义
=
= 开头表示精确匹配,如果这个查询匹配,那么将停止搜索并立即处理此请求。
^~
^~开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则^~ /static/ /aa匹配到(注意是空格)
~
~ 开头表示区分大小写的正则匹配
~*
~* 开头表示不区分大小写的正则匹配
!~和!~*
!~和!~*分别为区分大小写不匹配及不区分大小写不匹配的正则
/
用户所使用的代理(一般为浏览器)
$http_x_forwarded_for
可以记录客户端IP,通过代理服务器来记录客户端的ip地址
$http_referer
可以记录用户是从哪个链接访问过来的
语法示例:
location = /static/img/file.jpg { ... }1、普通前缀匹配
语法示例:
location /static/img/ { ... }2、优先前缀匹配
语法示例:
location ^~/static/img/ { ... }1、区分大小写
语法示例:
location ~ /static/img/.*\\.jpg$ { ... }2、不区分大小写
语法示例:
location ~* /static/img/.*\\.jpg$ { ... }3、区分大小写取反
语法示例:
location !~ /static/img/.*\\.jpg$ { ... }4、不区分大小写取反
语法示例:
location !~* /static/img/.*\\.jpg$ { ... }对于请求: 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 中记住的最长前缀匹配
那么产生的效果如下:
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作为方向代理服务器存在。
#直接匹配网站根,通过域名访问网站首页比较频繁,使用这个会加速处理。
#这里是直接转发给后端应用服务器了,也可以是一个静态首页
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/ }
参考文章:
1.https://www.jianshu.com/p/5b4067f9fbc
2.https://blog.csdn.net/zwl18210851801/article/details/81699977