内容简介:各种排列组合,重启服务,然后分别:官方文档,配合实际验证:简单总结:
语法
Syntax : location [ = | ~ | ~* | ^~ ] uri { ... } location @name { ... } Default: — Context: server, location
测试环境
server { listen 8888; # location ~ /foo/bar { return 501; } # location ~* /foo/bar { return 502; } # location = /foo/bar { return 503; } # location ^~ /foo/bar { return 504; } # location /foo/bar { return 505; } }
各种排列组合,重启服务,然后分别:
curl http://localhost:8888/foo/bar/a curl http://localhost:8888/foo/bar
结论
官方文档,配合实际验证:
简单总结:
-
执行顺序是:完整匹配(
= uri
) > 前缀匹配(^~ uri
/uri
) > 正则匹配(~
/~*
)。 - 优先级是:完整匹配 > 正则匹配 > 前缀匹配(越长优先级越高)。
- 完整匹配、正则匹配成功后直接返回,前缀匹配则不是。
详细说明:
-
先执行完整匹配规则
= uri
,如果匹配成功(一字不差)就直接返回,不再继续匹配 -
再执行前缀匹配规则
^~ uri
或uri
,不会立即返回,会先记下,看下面有没有优先级更高的-
uri
和^~ uri
同时出现会报 duplicate location,让人怀疑它俩是不是本来就相等。 -
注意
:按照规则长度,长的会覆盖短的(最大前缀规则)。
不知道实际实现如何,总之,从结论上来看,可以理解成和配置文件书写顺序无关。
-
-
再正则匹配(
~
大小写敏感,~*
大小写不敏感)- 遇到一个匹配成功的就直接返回,与配置文件书写顺序有关
- 如果正则匹配全部失败,就采纳普通匹配结果,如果普通匹配也全部失败,就 404
关于 @name
命名规则
location / { error_page 404 = @fallback; } location @fallback { proxy_pass http://backend; }
location / { try_files /system/maintenance.html $uri $uri/index.html $uri.html @mongrel; } location @mongrel { proxy_pass http://mongrel; }
- 不用于请求路径的解析,而是用于请求重定向
- 不能被嵌套,也不能嵌套别的 location
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据挖掘导论
Pang-Ning Tan, Michael Steinbach / 范明 范宏建 / 人民邮电出版社 / 2006-01-01 / 49.00元
本书全面介绍了数据挖掘的理论和方法,旨在为读者提供将数据挖掘应用于实际问题所必需的知识。本书涵盖五个主题:数据、分类、关联分析、聚类和异常检测。除异常检测外,每个主题都包含两章:前面一章讲述基本概念、代表性算法和评估技术,后面一章较深入地讨论高级概念和算法。目的是使读者在透彻地理解数据挖掘基础的同时,还能了解更多重要的高级主题。此外,书中还提供了大量示例、图表和习题。 本书适合作为......一起来看看 《数据挖掘导论》 这本书的介绍吧!