nginx配置文件中的location详解

来源:互联网 发布:淘宝客商品编辑软件 编辑:程序博客网 时间:2024/04/29 06:40

一、location语法简介及用法:
 URL地址匹配是Nginx配置中最灵活的部分.location 支持正则表达式匹配,也支持条件匹配,用户可以通过location指令实现Nginx对动丶静态网页的过滤处理。



1.语法规则: 
location [=|~|~*|^~] /uri/ { 
… 

}

1.1 = 开头表示精确匹配


1.2 ^~ 开头表示uri以某个常规字符串开头,理解为匹配 url路径即可。nginx不对url做编码,因此请求为/static/20%/aa,可以被规则


^~ /static/ /aa匹配到(注意是空格)。


1.3 ~ 开头表示区分大小写的正则匹配


1.4 ~*  开头表示不区分大小写的正则匹配


1.5 !~和!~*分别为区分大小写不匹配及不区分大小写不匹配 的正则


1.6 / 通用匹配,任何请求都会匹配到。


2.规则分类:

其中“~ ”和“~* ”以及“!~”和“!~*”前缀表示正则location .


其他前缀(包括:“=”,“^~”和“@ ”)和无任何前缀的都属于普通location .


3.匹配规则: 

普通 location ”的匹配规则是“最大前缀.(特殊的是“=”和“^~”,前缀指令将严格匹配uri ,如果匹配,停止搜索 .)


正则 location ”的匹配规则是“顺序匹配,且只要匹配到第一个就停止后面的匹配.


通用匹配 “/”最后匹配


先匹配普通 location ,再“考虑”匹配正则 location 。注意这里的“考虑”是“可能”的意思,也就是说匹配完“普通 location ”后,有的时候需要继续匹配“正则 location ”,有的时候则不需要继续匹配“正则 location ”。两种情况下,不需要继续匹配正则 location :( 1 )当普通 location 前面指定了“ ^~ ”,特别告诉 Nginx 本条普通 location 一旦匹配上,则不需要继续正则匹配;( 2 )当普通location 恰好严格匹配上,不是最大前缀匹配,则不再继续匹配正则.


总结:正则 location 匹配让步普通 location 的严格精确匹配结果;但覆盖普通 location 的最大前缀匹配结果.




二丶例子,有如下匹配规则:
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
}
那么产生的效果如下:

访问根目录/, 比如http://localhost/ 将匹配规则A  #因为A是精确匹配.


访问 http://localhost/login 将匹配规则B,http://localhost/register 则匹配规则H


访问 http://localhost/static/a.html 将匹配规则C


访问 http://localhost/a.gif 将匹配规则D和规则E,但是规则D顺序优先,规则E不起作用, 而http://localhost/static/c.png 则优先匹配到 规则C


访问 http://localhost/a.PNG 则匹配规则E, 而不会匹配规则D,因为规则E不区分大小写。


访问 http://localhost/a.xhtml 不会匹配规则F和规则G,http://localhost/a.XHTML不会匹配规则G,因为不区分大小写。规则F,规则G属于排除法,符合匹配规则但是不会匹配到,所以想想看实际应用中哪里会用到。


访问 http://localhost/category/id/1111 则最终匹配到规则H,因为以上规则都不匹配,这个时候应该是nginx转发请求给后端应用服务器,比如FastCGI(php),nginx作为方向代理服务器存在。


所以实际使用中,个人觉得至少有三个匹配规则定义,如下:

#直接匹配网站根,通过域名访问网站首页比较频繁,使用这个会加速处理,官网如是说。

#这里是直接转发给后端应用服务器了,也可以是一个静态首页

# 第一个必选规则

location = / {
   proxy_pass http://tomcat: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://tomcat:8080/
}


0 0
原创粉丝点击