Nginx基础之location匹配规则实践篇

location介绍

location指令的功能是用来匹配不同的url请求,进而对请求做不同的处理和响应

location语法

语法:location [=|^~|~|~*|@] /uri/ { … }
介绍:

前缀说明
location后没有参数直接跟着URI,表示前缀匹配,代表跟请求中的URI从头开始匹配; 如/, 表示通用匹配,任何未匹配到其它location的请求都会匹配到, 类似于switch…case中的default语句
~表示该规则是使用正则定义的,区分大小写;
~*表示该规则是使用正则定义的,不区分大小写;
^~表示最大前缀匹配,不做正则匹配检查。如果匹配成功,就采用该规则,不再进行后续的查找(即不再匹配其他location)。多用来匹配目录;
=表示进行普通字符精确匹配。也就是完全匹配。只有请求的url路径与后面的字符串完全相等时,才会命中;
@定义一个命名的 location,@定义的locaiton名字一般用在内部定向,例如error_page, try_files命令中

小结:
~* 前缀表示正则location , 其他( 如=、^~和@, 无任何前缀)属于普通location

测试

下面我们就一一测试下

测试/

先来配置下nginx, 可以在nginx.conf主配置文件中http{...} 段中加上include servers/*;(include指令用于从外部文件中引入配置参数),如果有的话就直接下一步。 接着我们在同级目录下新建servers文件夹,再新建一个配置文件如location.conf, 配置如下:

server {
    listen 80;
    server_name 127.0.0.1;
    location / {
        return 400;
    }
}

当然你也可以使用Nginx echo模块(可以直接在nginx中直接输出字符串,方便用户在做nginx配置时进行调试)测试location匹配优先级, 这里我们使用return

配置return简单说明:

语法:	return code [text];
        return code URL;
        return URL;
默认值:	无
上下文:	server, location, if

该指令将结束执行直接返回指定的状态码到客户端。 其中非标准代码 444 将关闭连接而不发送响应头。
修改完后重启nginx: nginx -s reload

测试结果:
curl命令 curl -I http://127.0.0.1:80/结果如下:
HTTP/1.1 400 Bad Request

测试 curl -v http://127.0.0.1:80/xxx结果依然是一样的
由于/是通配的,匹配任何请求,因为所有请求都是以”/“开始,但它的优先级我们暂时还不知道, 我们可以再加上/documents配置测试下:

测试/documents

增加配置

location / {
    return 400;
}
location /documents {
    return 401;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I http://127.0.0.1:80/documents结果如下:
HTTP/1.1 401 Unauthorized

如果存在多个普通前缀location,那如何匹配呢?
增加以下配置:

location /documents/word {
    return 200;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I http://127.0.0.1:80/documents/word结果如下:
HTTP/1.1 200 OK

小结:
/匹配所有以 / 开头的请求。但是如果有更长的同类型的表达式,则选择更长的表达式。即最大前缀匹配

测试~* /documents

~* 表示该规则是使用正则定义的,不区分大小写;

location ~* /documents {
    return 402;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I http://127.0.0.1:80/documents结果如下:
HTTP/1.1 402 Payment Required

从结果可以看出来正则的优先级要大于location /location /documents

测试~ /documents

~ 表示该规则是使用正则定义的,区分大小写;

location ~ /documents {
    return 403;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I http://127.0.0.1:80/documents结果如下:
HTTP/1.1 402 Payment Required

看结果是匹配了 ~* /documents;
现在我们改变下顺序:

location ~ /documents {
    return 403;
}
location ~* /documents {
    return 402;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I http://127.0.0.1:80/documents结果如下:
HTTP/1.1 403 Forbidden
此时结果就匹配了~ /documents

小结:
当同时有多个正则匹配时,按其在配置文件中出现的先后顺序优先匹配,命中则立即停止其他类型匹配;

测试^~ /documents/

^~ 表示普通字符匹配。使用前缀匹配。如果匹配成功,就采用该规则,不再进行后续的查找(即不再匹配其他location);多用来匹配目录。

location ^~ /documents/ {
    return 404;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I http://127.0.0.1/documents/1结果如下:
HTTP/1.1 404 Not Found

测试 = /documents

增加以下配置:

location = /documents {
    return 405;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I curl -I http://127.0.0.1/documents结果如下:
HTTP/1.1 405 Not Allowed

小结:
= 表示进行普通字符精确匹配。也就是完全匹配。只有请求的url路径与后面的字符串完全相等时,才会命中; 匹配优先级最高

测试 @

@ 定义一个命名的 location,@定义的locaiton名字一般用在内部定向,例如error_page, try_files命令中

如配置error_page, 增加以下配置:

location /500 {
    error_page 500 = @index_error;
    return 500;
}
location @index_error {
    return 200;
}

修改完后重启nginx: nginx -s reload
curl命令 curl -I curl -I http://127.0.0.1/500结果如下:
HTTP/1.1 200 OK

配置try_files如下:

location / {
    # ...
    try_files $uri $uri/ @index;
    index  index.html index.htm;
}

location @index  {
    rewrite ^/(.*)$   / permanent;
}

匹配优先级

以上测试已经证明过, 结论: = > ^~ > ~|~* > /

优先级示例

配置项如下:

location = / {
# 仅仅匹配请求 /
# 规则A
}
location / {
# 匹配所有以 / 开头的请求。但是如果有更长的同类型的表达式,则选择更长的表达式。如果有正则表达式可以匹配,则优先匹配正则表达式。
# 规则B 
}
location /documents/ {
# 匹配所有以 /documents/ 开头的请求。但是如果有更长的同类型的表达式,则选择更长的表达式。如果有正则表达式可以匹配,则优先匹配正则表达式。
# 规则C
}
location ^~ /images/ {
# 匹配所有以 /images/ 开头的表达式,如果匹配成功,则停止匹配查找。所以,即便有符合的正则表达式location,也不会被使用规则D
}
location ~* \.(gif|jpg|jpeg|png|js|css)$ {
# 匹配所有以 gif jpg jpeg结尾的请求。但是 以 /images/开头的请求,将使用规则D
# 规则E
}

请求匹配示例:
访问根目录/ -> 如http://localhost/ 将匹配规则A;
访问http://localhost/index.html -> 将匹配规则B;
访问http://localhost/documents/document.html -> 将匹配规则C;
访问http://localhost/images/1.gif -> 将匹配规则D;
访问http://localhost/static/index.css -> 将匹配规则E;

注意,以上的匹配和在配置文件中定义的顺序无关。

最后, 如有错误,欢迎各位大佬指点!感谢!

参考资料

http://nginx.org/en/docs/http/ngx_http_rewrite_module.html#return
https://blog.csdn.net/weixin_43898125/article/details/108069874

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: nginxlocation匹配规则是根据请求的URI(Uniform Resource Identifier)来匹配location指令中的模式,从而确定应该由哪个location块来处理该请求。nginxlocation匹配规则有以下几种: 1. 精确匹配:如果location指令中的模式与请求的URI完全一致,则匹配成功。 2. 前缀匹配:如果location指令中的模式是以“/”开头的字符串,则匹配请求URI中以该字符串开头的部分。 3. 正则匹配:如果location指令中的模式是一个正则表达式,则匹配请求URI与该正则表达式的匹配结果。 4. 最长前缀匹配:如果有多个location指令的模式都能匹配请求URI,则选择最长的那个模式来处理请求。 5. 通用匹配:如果没有任何location指令能够匹配请求URI,则使用通用匹配来处理请求。 以上就是nginxlocation匹配规则,可以根据实际需求选择不同的匹配方式来处理请求。 ### 回答2: nginx是一个高性能的Web服务器、反向代理和负载均衡器,它广泛用于各种(动态)网站和Web应用程序的部署中。在nginx中,location是一个非常重要的配置指令,它可以帮助服务器根据请求的URL路径(URI)匹配指定的服务或文件。 location匹配规则如下: 1. 精确匹配(=):只有当请求URI与location指定的URI完全匹配时,才会执行该location指令之后的操作。 例如: location = /hello { return 200 "Hello, nginx!\n"; } 当访问/hello时,会直接返回"Hello, nginx!"字符串,不会再进行其他的匹配和处理。 2. 前缀匹配(^~):如果请求URI以location指定的前缀开头,那么该location指令之后的操作将被执行。 例如: location ^~ /images/ { alias /var/www/myapp/static/images/; } 当访问/images/logo.png时,该请求将被映射到服务器文件系统中的/var/www/myapp/static/images/logo.png文件。 3. 正则表达式匹配(~和~*):location指定的URI可以是一个正则表达式,如果请求URI与该正则表达式匹配成功,则该location指令之后的操作将被执行。 其中,~表示区分大小写的正则表达式匹配,而~*表示不区分大小写的正则表达式匹配。 例如: location ~ /users/([0-9]+)/photos/(.*)\.jpg$ { proxy_pass http://backend_server/photos/$1/$2.jpg; } 当访问/users/123/photos/myphoto.jpg时,该请求将被映射到http://backend_server/photos/123/myphoto.jpg后端服务器上进行处理。 4. 普通匹配:如果以上三种匹配规则都不匹配成功,那么nginx会采用普通匹配规则。首先,nginx会查找URI中是否包含文件扩展名,如果有,则nginx会按照扩展名指定的类型进行处理;如果没有,nginx则会使用server指令中指定的默认类型进行处理。 例如: location / { index index.html index.php; try_files $uri $uri/ /index.php?$query_string; } 当访问任何URI时,都会先查找该URI所对应的文件是否存在,如果存在,则直接返回该文件内容;否则,重定向到/index.php页面进行处理。 总之,在nginx中,location是一个非常强大的配置指令,可以根据不同的匹配规则,灵活地配置不同的服务和文件,从而提高网站的性能和稳定性。熟练掌握location匹配规则对于nginx的使用和维护都是非常重要的。 ### 回答3: Nginx是一种高性能的Web服务器和反向代理服务器,同时也是一个邮件代理服务器。当使用Nginx作为Web服务器时,可以使用location匹配规则来确定如何处理请求。location匹配规则Nginx服务器使用的一个非常重要的配置选项。它可让用户在指定的URL路径中,对请求做出特定的响应。 Nginxlocation匹配规则可以分为两种类型:正则和非正则。正则匹配是基于正则表达式的匹配。它可以根据URL路径中的模式匹配,使用正则表达式的语法来表示匹配规则。非正则匹配是基于URL路径的匹配。它可以直接匹配特定的URL路径,而不需要使用正则表达式。 当Nginx服务器接收到一个请求时,它首先会按照配置文件中location的顺序进行匹配匹配成功后,Nginx会按照顺序处理该请求,直到找到一个匹配完全符合要求的location为止。如果找不到一个匹配完全符合请求的location,则会使用默认的location做出响应。 对于正则匹配规则,需要使用~或~*开头,其中~表示区分大小写,~*表示不区分大小写。比如:location ~ ^/download/.+\.(zip|rar)$ {},表示当请求路径以/download/开头,并且以.zip或.rar结尾时,使用当前配置块进行处理。 对于非正则匹配规则,需要使用=或^~开头,其中=表示完全匹配,^~表示使用前缀匹配。比如:location = /index.html {},表示当请求路径为/index.html时,使用当前配置块进行处理。 除了以上两种匹配规则外,Nginx还提供了一些其他的匹配规则,比如按文件夹优先匹配,按通用优先匹配等,具体可以根据业务场景来选择相应的匹配规则,来达到更好的匹配效果。 总之,Nginxlocation匹配规则非常重要,可以用来处理各种不同的请求,帮助Web服务器实现更加灵活的请求处理方式,提高Web服务器的性能和安全性。熟悉和掌握Nginxlocation匹配规则,对于Web服务器的运维和开发都有着非常大的帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值