Nginx的location配置
使用nginx的时候,免不了要给各种服务做代理,不同的规则要配置不同的location
规则。
正则写法
- 精确匹配
精确匹配 /
,主机名(域名)后面不能带任何的字符串
1 | location = / { |
- 匹配所有请求
所有的请求地址都以 /
开头,这条规则就会匹配所有的请求,但是正则和最长的字符串会优先匹配到。
1 | location / { |
- 匹配任何以
某字符串
开头
假如现在以 test
和 image
开头,匹配符合以后,还要继续往下搜索,只有后面的正则表达式没有匹配到时,这一条才会采用这一条。
1 | location /test/ { |
- 匹配不同文件结尾
一般将静态资源放到nginx中代理出来,有一些文件 .png、.jpg
需要单独配置规则
1 | # 匹配所有以 gif,jpg或jpeg 结尾的请求 |
=
开头表示精确匹配
如 A 中只匹配根目录结尾的请求,后面不能带任何字符串。
^~
开头表示uri以某个常规字符串开头,不是正则匹配
~
开头表示区分大小写的正则匹配;
~*
开头表示不区分大小写的正则匹配
/
通用匹配, 如果没有其它匹配,任何请求都会匹配到
顺序
(location =) > (location 完整路径) > (location ^~ 路径) > (location ~,~* 正则顺序) > (location 部分起始路径) > (/)
匹配结果
上面的匹配结果,按照上面的location写法,以下的匹配示例成立:
/ -> config A
精确完全匹配,即使/index.html也匹配不了
/downloads/download.html -> config B
匹配B以后,往下没有任何匹配,采用B
/image/1.gif -> configuration E
匹配到F,往下匹配到E,停止往下
/image/abc/def -> config E
最长匹配到G,往下匹配D,停止往下你可以看到 任何以/image/开头的都会匹配到D并停止,F G写在这里是有任何意义的,H是永远轮不到的,这里只是为了说明匹配顺序
/documents/document.html -> config C
匹配到C,往下没有任何匹配,采用C
/documents/1.jpg -> configuration I
匹配到C,往下正则匹配到I
/documents/Abc.jpg -> config D
最长匹配到 C,往下正则顺序匹配到 D,不会往下到 I
原文作者: dgb8901,yinxing
原文链接: https://www.itwork.club/2020/04/13/nginx-location/
版权声明: 转载请注明出处
为您推荐
体验小程序「简易记账」
关注公众号「特想学英语」