nginx try_files指令的实现示例
try_files 用于指定文件的查找规则,可以配置多个规则,会按顺序执行查找规则,若找到文件则中断查找并返回文件,若找不到则返回404响应。
配置语法
location / { root html; index index.html; try_files $uri $uri/ /index.html; }
解释下配置:
- root指令 设置了 静态根目录 为 html。
- index指令 设置了 目录的默认文件 为 index.html。
- try_files指令 设置了 文件查找规则 为 $uri $uri/ /index.html。即3个规则,先从 $uri 查找,再从 $uri/ 目录中查找,最后查找 /index.html。
举个例子
针对上面的配置,当请求 http://localhost:8080/abc
时,则 $uri
为 /abc
,此时,try_files 的规则可以具体为 /abc
/abc/
/index.html
,/
表示根目录 html
(由 root指令 指定)。
其具体的查找逻辑如下:
检查 html
目录中是否存在 abc
文件(对应第1个规则)
- 如果存在,则返回文件
- 如果不存在,则继续下一步
检查 html
目录中是否存在 abc/
目录(对应第2个规则)
如果存在,则再检查 abc/
目录中是否存在 index.html
文件(由 index指令 指定)
- 如果存在,则返回文件
- 如果不存在,则默认返回403,因为目录不可访问;
如果不存在则继续下一步
检查 html
目录中是否存在 index.html
文件(对应第3个规则)
- 如果存在,则返回文件
- 如果不存在,则返回404
小结: 可以看到,try_files指令 的查找逻辑和 root指令、index指令 有很大的关系。
高级用法:
先在本地尝试查找文件,找不到则重定向到其他地址
location / { try_files $uri $uri.html $uri/ @mongrel; } location @mongrel { proxy_pass http://mongrel; }
到此这篇关于nginx try_files指令的实现示例的文章就介绍到这了,更多相关nginx try_files内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
详解Nginx反向代理实现会话(session)保持的两种方式
这篇文章主要介绍了详解Nginx反向代理实现会话(session)保持的两种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-08-08
最新评论