nginx location语法
第一优先级 = : 完全匹配。如果这个查询匹配,那么将停止搜索并立即处理此请求。
第二优先级 ^~ : 普通字符匹配。优先使用前缀匹配。如果匹配成功,则不再匹配其他location。
第三优先级 ~ : 区分大小写匹配
第三优先级 !~ : 区分大小写不匹配
第三优先级 ~* : 不区分大小写匹配
第三优先级 !~* : 不区分大小写不匹配
第四优先级 /{uri} : 不带任何修饰符,也表示前缀匹配,但是在正则匹配之后。
第四优先级 / : 通用匹配,任何未匹配到其它location的请求都会匹配到,相当于switch中的default。
1 | location = / { |
对于请求: http://example.com/static/img/logo.jpg
如果命中精确匹配,例如:
1 | location = /static/img/logo.jpg { |
则优先精确匹配,并终止匹配。
如果命中多个前缀匹配,例如:
1 | location /static/ { |
则记住最长的前缀匹配,即上例中的 /static/img/,并继续匹配
如果最长的前缀匹配是优先前缀匹配,即:
1 | location /static/ { |
则命中此最长的优先前缀匹配,并终止匹配
否则,如果命中多个正则匹配,即:
1 | location /static/ { |
则忘记上述 2 中的最长前缀匹配,使用第一个命中的正则匹配,即上例中的 location ~* /static/ ,并终止匹配(命中多个正则匹配,优先使用配置文件中出现次序的第一个)
否则,命中上述 2 中记住的最长前缀匹配
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 小五的个人杂货铺!
