目录

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如何发挥作用

 

nginx upload module 配置 nginx uri_正则匹配

 

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/
    }