nginx反向代理的那点事

今早一上班 Boss让部署个前后端分离的项目,本猿接到任务一看,so easy ,然后登录服务器一顿操作(我们用的docker环境)  太轻松了 半天我就搞定了服务器端,剩个nginx和前端项目下午还不是轻轻松松,然后我就发现草率了

安装nginx 打包编译前端代码 上传服务器 配置反向代理 1 2 3 4 搞定,啊 不对 4没搞定。前端访问后端接口404,然后检查配置文件 没毛病啊 重载还是不行 于是开始查看资料,认真核对发现 uri跳转代理时少加了/ 本来5点下班的节奏,

又一次搭上了最后一般地铁。

在nginx中配置proxy_pass代理转发时,如果在proxy_pass后面的url加/,表示绝对根路径;如果没有/,表示相对路径,把匹配的路径部分也给代理走。

假设下面四种情况分别用 http://192.168.1.1/proxy/test.html 进行访问。

第一种:
location /proxy/ {
proxy_pass http://127.0.0.1/;
}
代理到URL:http://127.0.0.1/test.html

第二种(相对于第一种,最后少一个 / )
location /proxy/ {
proxy_pass http://127.0.0.1;
}
代理到URL:http://127.0.0.1/proxy/test.html

第三种:
location /proxy/ {
proxy_pass http://127.0.0.1/aaa/;
}
代理到URL:http://127.0.0.1/aaa/test.html

第四种(相对于第三种,最后少一个 / )
location /proxy/ {
proxy_pass http://127.0.0.1/aaa;
}
代理到URL:http://127.0.0.1/aaatest.html

 

参考文档:https://blog.csdn.net/u010433704/article/details/99945557

Guess you like

Origin blog.csdn.net/u012153904/article/details/112498751