📋 Location配置优先级规则
在nginx配置文件中,location主要有以下几种形式,以下按优先级自高到低列出:
- 精确匹配
location = /abc { }
- 匹配路径的前缀,如果找到停止搜索
location ^~ /abc { }
- 不区分大小写的正则匹配
location ~* /abc { }
- 正则匹配
location ~ /abc { }
- 普通路径前缀匹配
location /abc { }
📝 优先级总结
= 绝对匹配最高,^~ 开头其次,~ 带 * 再次,不带 * 次之,直接前缀最后。
🔍 特别案例
/images/前缀优先
location ^~ /images/ {
# 匹配任何以 /images/ 开头的地址,匹配符合以后,停止往下搜索正则,采用这一条。
[ configuration D ]
}
文件扩展名结尾,不区分大小写其次
location ~* \.(gif|jpg|jpeg)$ {
# 匹配所有以 gif,jpg或jpeg 结尾的请求
# 然而,所有请求 /images/ 下的图片会被 config D 处理,因为 ^~ 到达不了这一条正则
[ configuration E ]
}
不带*再次
location ~ /images/abc/ {
# 只有去掉 config D 才有效:先最长匹配 config G 开头的地址,继续往下搜索,匹配到这一条正则,采用
[ configuration H ]
}
/images/abc前缀,优先级高于以下/images/前缀
location /images/abc {
# 最长字符匹配到 /images/abc,继续往下,会发现 ^~ 存在
# F与G的放置顺序是没有关系的
[ configuration G ]
}
/images/前缀,但是没有任何修饰符,优先级最后
location /images/ {
# 字符匹配到 /images/,继续往下,会发现 ^~ 存在
[ configuration F ]
}
⚠️ 注意事项
- 精确匹配优先级最高,一旦匹配成功立即停止搜索
^~
前缀匹配成功后会停止正则表达式的匹配- 正则表达式按照在配置文件中出现的顺序进行匹配
- 普通前缀匹配会选择最长的匹配项