Nginx配置文件Location匹配规则

Location根据类型分为两种:普通配置和正则匹配

一、普通配置

普通location根据使用方法又分为两种,格式如下:

1.  location  / {

命令序列

}

解释:括号中定义的表示对当前路径及子路径下的所有对象有效。优先级最低

用户所有的请求都能被它匹配到。

例子:

location / {       

              root /web; 

                相应策略     

    }

        这说明网页根目录在/web

        访问的时候直接http://127.0.0.1或是域名就可以了

        用户所有的请求都能被它匹配到

       

location /bbs {

       root "/web";

         相应策略

}

这就说明网页根目录是位于  /web/bbs

访问的时候直接http://127.0.0.1/bbs就可以了

当用户访问

http://127.0.0.1/bbs/

或是

http://127.0.0.1/bbs/子路径的时候才能被上边的路径匹配到

        问题:当用户访问http://127.0.0.1/bbs/a.html

        这两段location 同时存在时如下,那么哪段配置会生效呢?       

server {

        listen       80;

        server_name  www.benet.com;

        index index.html;

        location  / {

                root /web;

        }

        location  /bbs {

                root /web;

        }

结论就是,

当用户请求的(/bbs)url同时匹配到两段location时,

最大前缀生效(location /bbs生效

如果没有这段(location /bbs第一段生效。

第一段相当于默认策略,因为location / 包含所有的请求,所有的请求都是以  ”/” 开始的

2.  location = /路径 {

命令序列

}

解释:括号中定义的表示对当前路径有效,子路径不生效(精确匹配指定的路径不包括子路径)。“它的优先级最高。”

例子:

location = /prefix {

}

也就是用户访问www.benet.com/prefix能被上边的location匹配到,它只匹配"/prefix",

"/"下的子路不匹配。

用户访问www.benet.com/prefix/a 就不能被它匹配到

优先级最高:指的是一旦匹配到此location ,立即生效。其它location无论是否匹配到请求都不生效。

例子:

location  /prefix/ {

                root /;

        }

location  = /prefix/  {

               return 507;

       }

匹配顺序注解:

二、正则匹配

正则匹配也分为两种:

  1. location ~ URI {}

~匹配的文件是区分字符 大小写的

2.location ~* URI {} :

~*匹配的文件是不区分字符大小的

   

    正则匹配是按照正则location编写的顺序生效的,一旦匹配成功即停止匹配到后续的location

例子:

   location  ~ /bbs {

                return 400;

    }

   location ~* /bbs {

                return 500;

   }

网页返回错误信息400

然后将两段配置调换一下位置

  location ~* /bbs {

                return 500;

        }

  location  ~ /bbs {

                return 400;

        }

三、匹配顺序和生效顺序

匹配顺序和生效顺序是两个概念

当配置中出现多个locaton并且普通和正则都有,那么

1、匹配顺序是:

    用户请求的URL

    1)先匹配普通location

            普通location在匹配是按照编辑顺序匹配

    2)在匹配正则location

            正则location在匹配时按照编辑顺序匹配

但是正则和普通locaiton不按照编辑顺序匹配

2、生效顺序

当普通和正则都存在的情况下,遵循以下原则

1.nginx开始按照编辑顺序依次匹配普通location

    (1)如果匹配过程中匹配到了

        "location =" :nginx会立即生效即停止后续的匹配

    (2)如果没有"locaiton ="话,

        如果匹配到"locatin ^~"。会停止后续的正则匹配.然后此策略立即生效。

    

    (3)    如果以上两种location都不存在的话

        nginx会匹配所有location后看后续有没有正则locaion

            如果后续没有正则locaiton

                然后最大前缀locaiton生效

                最后是location / 生效

            如果后续还有正则location

                一旦匹配成功一条正则locaion,这条会生效,并且会停止后续的正则匹配,还会会覆盖前边的普通location结果 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值