=:进行普通字符精确匹配。也就是完全匹配
^~:前缀匹配。如果匹配成功,则不再匹配其他location
~:表示执行一个正则匹配,区分大小写
~*:表示执行一个正则匹配,不区分大小写
/xxx/:常规字符串路径匹配
/:通用匹配,任何请求都会匹配到
等号类型(=)的优先级最高。一旦匹配成功,则不再查找其他匹配项,停止搜索。
^~类型表达式,不属于正则表达式。一旦匹配成功,则不再查找其他匹配项,停止搜索。
正则表达式类型(~ ~*)的优先级次之。如果有多个location的正则能匹配的话,则使用正则表达式最长的那个。
常规字符串匹配类型。按前缀匹配。
/ 通用匹配,如果没有匹配到,就匹配通用的
优先级搜索问题:不同类型的location映射决定是否继续向下搜索。
等号类型、^~类型:一旦匹配上就停止搜索了,不会再匹配其他location了正则表达式类型(~ ~*),常规字符串匹配类型/xxx/:匹配到之后,还会继续搜索其他其它location,直到找到优先级最高的,或者找到第一种情况而停止搜索
location优先级从高到底:
(location =)>(location 完整路径)>(location ^~ 路径)>(location ~,~* 正则顺序)>(location 部分起始路径)>(/)
1 location = / { 2 # 精确匹配/,主机名后面不能带任何字符串 / 3 [ configuration A ] 4 } 5 location / { 6 # 匹配所有以 / 开头的请求。 7 # 但是如果有更长的同类型的表达式,则选择更长的表达式。 8 # 如果有正则表达式可以匹配,则优先匹配正则表达式。 9 [ configuration B ] 10 } 11 location /documents/ { 12 # 匹配所有以 /documents/ 开头的请求,匹配符合以后,还要继续往下搜索。 13 # 但是如果有更长的同类型的表达式,则选择更长的表达式。 14 # 如果有正则表达式可以匹配,则优先匹配正则表达式。 15 [ configuration C ] 16 } 17 location ^~ /images/ { 18 # 匹配所有以 /images/ 开头的表达式,如果匹配成功,则停止匹配查找,停止搜索。 19 # 所以,即便有符合的正则表达式location,也不会被使用 20 [ configuration D ] 21 } 22 23 location ~* \.(gif|jpg|jpeg)$ { 24 # 匹配所有以gif jpg jpeg结尾的请求。 25 # 但是 以/images/开头的请求,将使用Configuration D,D具有更高的优先级 26 [ configuration E ] 27 } 28 29 location /images/ { 30 # 字符匹配到/images/,还会继续往下搜索 31 [ configuration F ] 32 } 33 34 35 location = /test.htm { 36 root /usr/local/var/www/htm; 37 index index.htm; 38 }
注意:location的优先级与location配置的位置无关。