| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 系统运维 -> Nginx的alias/root/try_files实战 -> 正文阅读 |
|
[系统运维]Nginx的alias/root/try_files实战 |
项目背景前端Vue项目,同时支撑PC网站、手机M站和手机App,在项目构建之后会有三个子目录作为路由分别对应m站、PC和APP,但是该项目作为一个服务对外提供服务需要一个统一的请求入口,比如
而不是在每个域名下各自己配置不同的入口,比如
这样的配置虽然从实现是没有问题的,但是从运维维护成本上来说很大,如果它以后要支撑不同的渠道,那就是在N多配置文件中添加N多类似的配置 当前项目的目录结构如下
遇到问题因为是前端资源,还涉及到静态资源问题,前端项目为了统一标准,一般都会有个识别的前缀,比如,不管是从PC还是APP过来的请求,
那么如下请求是没有问题的
但是如果请求上带上参数的,一般都是通过 参考: 所有上面的配置变为
但是结果却未出人意外,请求404报错,提示文件不存在,但是文件自己确认是存在,那就是配置的问题。
问题分析解决1、既然不能共存,但是要实现优雅的URL,请求不存在的时候转发到指定的HTML页面,但是try_files是必须的 2、既然try_files得用,除了alias之外,就只能用 root了 至于alias和root的区别,简单来说:
3、但是如果使用 root,根据其作用,知道 location就不能使用view了,同时前端规范静态资源请求还是需要view的,那么view的配置还是需要保留,然后做静态资源请求 4、既然view保留做静态资源,那么路由就需要另外的路由入口,和开发协商,项目产生物结构变更为如下:
pm-live作为入口路由,Nginx的配置如下
又遇到问题 原因在于try_files 会按照顺序就检索对应的Uri是否存在,不存在就查找下一个。这里 既然找到问题,上面的配置会导致循环重定向,那就想办法让他跳出‘循环’,再结合 伪静态实际最终也是要转原生URL的,肯定会用到rewrite,所以进行如下配置变更
最终验证实现开发需要的需求
总结通过上面的案例我们学习到以下知识点 1、root和alias对uri的处理有区别,alias会截取 2、Nginx的 alias 和try_files 两个之间存在互斥,不能同时配置 3、一般实现伪静态采用 root+try_files 就够了 4、但是存在动态URL的时候,需要用 root+try_files+单独带@的location的rewrite 5、凡是涉及到Nginx的location配置,那就需要了解Nginx location的几种方式及其优先级 6、另外就是Nginx URL的正则匹配,在实现rewrite重写的时候尤为重要 附加Nginx location类型及优先级 精准匹配
字符串匹配
正则匹配
通用匹配
所以这几个的优先级为:
源站地址:http://blog.colinspace.com/2022/03/09/nginx-alias-root-and-try-files/ 人生漫漫路,坚持一起学~ |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/9 17:15:05- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |