一、location模块的匹配模式
1. 匹配模式种类
location模块的基本语法:
location [匹配模式] 路径 {
}
- =:精确匹配。
- ~:区分大小写的正则匹配。
- ~*:不区分大小写的正则匹配。
- ^~:前缀匹配路径。
- !~:区分大小写的不匹配。
- !~*:不区分大小写的不匹配。
2. 匹配模式的优先级
2.1 匹配流程
当有多个location模块时,匹配URL的顺序是:精确匹配 > 前缀匹配 > 正则表达式匹配 > 普通匹配 > 通用匹配。location的匹配除了讲究顺序匹配外,还讲究最长匹配,下面是具体的匹配流程。
- 检查是否属于精确匹配。
- 检查最长的非正则表达式匹配。
- 如果最长匹配的属于是普通匹配,那么继续进行正则表达式匹配;如果是前缀匹配,那么不进行正则表达式匹配。
- 如果都没有,则进行通用匹配。
2.2 匹配示例
location /test_1 {
return 400;
}
location ~ /test {
return 401;
}
location ^~ /test {
return 402;
}
上面是一个location示例,当请求URL路径是/test_1时,匹配流程如下:
- 先查看是否存在精确匹配,这里没有。
- 查看最长非正则表达式匹配,这里的最长匹配就是location /test_1,属于普通匹配。
- 如何进行正则表达式匹配,匹配到location ~ /test,所以最后的返回结果是401。
3. location匹配的常见使用
-
精确匹配
常用于匹配网站的根目录,或者网站首页。网站的首页基本上都是静态网页,通过精确匹配可以提高首页的访问速度。
-
前缀匹配或者正则表达式实现后缀匹配
常用于处理静态文件的请求,通过前缀或者后缀进行匹配对应的静态文件。
-
通用匹配
一般用于匹配包含.php或者.jsp的动态请求。
二、location重定向
1. 重定向概述
重定向就是请求网站之后会自动跳转到设定的目标网站。在Nginx中使用rewrite实现网页的重定向,使用nginx提供的全局变量或者自定义变量,结合正则表达式和标志位实现URL(URI)的重定向。
2. 重定向的使用场景
- 更换域名。
- 网站维护,又不想中断服务,可以通过URL的跳转来访问正常服务器。
- 防盗链。
3. rewrite语法
使用rewrite需要Nginx下载支持该模块,编译安装时要指定该模块。可以结合if语句进行条件判断,根据情况是否进行重定向跳转,但是没有else语句。
rewrite的基本语法如下:
rewrite 正则表达式 目标URL 标记
-
正则表达式:匹配请求的URL路径。
-
目标URL:重定向跳转后的URL路径。
-
标记:rewrite的重定向标记。
- permanent :永久重定向,返回状态码301。搜索引擎的排名和权重会转移到新URL,客户端保留新的URL。
- redirect :临时重定向,返回状态码302。常用于维护,搜索引擎的排名和权重不会转移到新URL,客户端继续访问原始URL。
- break:不会改变访问的URL,匹配到本规则就会停止,返回状态码不是3字头的状态码。
- last:匹配完本规则会继续匹配location。使用last一旦陷入死循环,循环超过10次就会停止,并返回500状态码。
返回状态码500的常见原因:
- 服务器故障。
- 防火墙屏蔽。
- 应用端口未启用,常见情况包括配置文件错误、端口被占用、服务器资源不足。
- last匹配机制导致陷入死循环。
Nginx中location模块匹配与重定向详解

307

被折叠的 条评论
为什么被折叠?



