频道栏目
首页 > 资讯 > 其他 > 正文

try_files实例解析

18-07-20        来源:[db:作者]  
收藏   我要投稿

以下述配置文件为例:

 location ~ \.php$ {
            root           html;
            try_files      $uri $uri/ =404;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            include        fastcgi_params;
        }

try_files的第一个‘$uri’代表nginx会去硬盘的对应路径寻找文件,如果能找到,则向下执行location块中的内容,也就是把找到的文件交给fastcgi执行,如果找不到,则尝试在访问的uri后面追加‘/’,并继续在硬盘中寻找对应目录,处理同上,否则将这次请求内部重定向到最后一个参数,也就是返回404。

这里需要注意几点:

一是访问’your.site.com/example‘时,若没有配置’$uri/‘则nginx只会去找对应的example文件,而不会找example目录;若访问’your.site.com/example/‘,nginx只会去找对应的example目录,而不会找example文件。也就是说若没有try_files这项配置,nginx会完全按照请求的uri去硬盘中找文件(不以’/‘结尾)或目录(以’/‘结尾),不会擅自加添或去掉'/'。

二是try_files只是让nginx’尝试去找文件‘,找完不会直接跳出location块,而是会顺着往下执行,后面有proxy_pass或fastcgi_pass则将找到的文件转发到对应的地方,没有proxy_pass或fastcgi_pass则直接将文件返回给客户端。当找不到文件时,将这次请求内部重定向到最后一个参数,所以最后一个参数必须存在,例如 ‘=404’或重定向到其他的location等等,若不存在,则可能出现服务器内部异常,例如循环重定向的异常。

相关TAG标签
上一篇:MySQL数据库的高可用架构方案实例讲解
下一篇:Java equals方法的两种重写场景及方式讲解
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站