nginxlocation优先级的深⼊讲解
location表达式类型
~ 表⽰执⾏⼀个正则匹配,区分⼤⼩写
~* 表⽰执⾏⼀个正则匹配,不区分⼤⼩写
^~ 表⽰普通字符匹配。使⽤前缀匹配。如果匹配成功,则不再匹配其他location。
= 进⾏普通字符精确匹配。也就是完全匹配。
@ "@" 定义⼀个命名的 location,使⽤在内部定向时,例如 error_page, try_files
location优先级说明
在nginx的location和配置中location的顺序没有太⼤关系。正location表达式的类型有关。相同类型的表达式,字符串长的会优先匹配。
以下是按优先级排列说明:
第⼀优先级:等号类型(=)的优先级最⾼。⼀旦匹配成功,则不再查其他匹配项。
第⼆优先级:^~类型表达式。⼀旦匹配成功,则不再查其他匹配项。
第三优先级:正则表达式类型(~ ~*)的优先级次之。如果有多个location的正则能匹配的话,则使⽤正则表达式
最长的那个。
第四优先级:常规字符串匹配类型。按前缀匹配。
location优先级⽰例配置项如下:
location = / {
# 仅仅匹配请求 /
[ configuration A ]
}
location / {
# 匹配所有以 / 开头的请求。但是如果有更长的同类型的表达式,则选择更长的表达式。如果有正则表达式可以匹配,则
# 优先匹配正则表达式。
[ configuration B ]
正则匹配开头}
location /documents/ {
# 匹配所有以 /documents/ 开头的请求。但是如果有更长的同类型的表达式,则选择更长的表达式。
#如果有正则表达式可以匹配,则优先匹配正则表达式。
[ configuration C ]
}
location ^~ /images/ {
# 匹配所有以 /images/ 开头的表达式,如果匹配成功,则停⽌匹配查。所以,即便有符合的正则表达式location,也
# 不会被使⽤
[ configuration D ]
}
location ~* \.(gif|jpg|jpeg)$ {
# 匹配所有以 gif jpg jpeg结尾的请求。但是以 /images/开头的请求,将使⽤ Configuration D
[ configuration E ]
}
请求匹配⽰例
/ -> configuration A
/index.html -> configuration B
/documents/document.html -> configuration C
/images/1.gif -> configuration D
/
documents/1.jpg -> configuration E
注意,以上的匹配和在配置⽂件中定义的顺序⽆关。
总结
到此这篇关于nginx location优先级的⽂章就介绍到这了,更多相关nginx location优先级内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。