Nginx 如何反向代理多个端口到同一端口不同目录上?
如何配置 Nginx 的反向代理,使多个端口代理到同一端口的不同目录上?
我有应用 a 、b 和 c ,各自运行在 8001 、8002 和 8003 端口上。
服务器没有配置域名,所以访问地址是 ip:8001 、ip:8002 和 ip:8003 。
现在我想用 Nginx 实现,只开放一个 80 端口,然后通过不同的目录来访问不同的服务。
我期望访问地址可以变成 ip:80/a 、ip:80/b 和 ip:80/c 。并且该应用下所有的资源请求都是基于该路径下。
比如 ip:80/a 可以跳转到 ip:80/a/login ,而不是 ip:80/login ,注意目录的不同。
我的 /etc/nginx/conf.d/default.conf 如下:
server {
listen 80;
server_name localhost;
location /a {
proxy_pass http://127.0.0.1:8001/;
}
location /b {
proxy_pass http://127.0.0.1:8002/;
}
location /c {
proxy_pass http://127.0.0.1:8003/;
}
}
按我上面的配置,输入 ip:80/a 的确看到成功代理了 ip:8001 的应用,只看首页,一切都是正常的。
但是一跳转 ip:80/a/user/** 这样的多级目录,就失败了,变成 ip:80/user/** 。
我也试过按官方文档,用正则配置 location 或用 rewrite ,都无法实现我想要的效果。
谢谢指教。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
请问你这个问题解决了吗,我现在遇到和你一样的情况,想讨教下最后怎么解决的。
问题在这里:
proxy_pass http://127.0.0.1:8001/;
这个是绝对路径的意思,所以他会忽略掉你的/a
你改成:
proxy_pass http://127.0.0.1:8001;
就可以了,答案对的话就采纳吧
location后面改成正则匹配啊
你最好看下官网
可以用Nginx的Module ngx_http_sub_module解决,并且需要注意反向代理的时候取消gzip
sub_filter + proxy_pass requires no gzip encoding - Today I Learned
我试过了,不可以的,除非有域名。
映射目录,代理的后端也要相应改动才行, 否则目录之间的关系无法一一保持。rewrite也是改写url, 没法改写后端页面html的a标签的url。大费周折得不偿失。
比较合理的办法是用二级域名对应不同后端服务。