docker nginx反向代理配置内部端口502 bad gateway

问题描述

服务器80端口被nginx占用,workerman通过8088端口提供服务,两个服务都在docker容器里

想让外部通过域名aaa.com访问到8088提供的服务,所以想通过域名访问到nginx,nginx将该域名的请求反向代理到内网的8088端口来。

nginx配置反向代理,配置文件如下

upstream spzh18 { server 127.0.0.1:8088; } server { # 默认监听 80 端口 listen 80; server_name aaa.com; location / { proxy_pass http://spzh18; index index.html index.htm; } access_log /www/spzh18/test.com.log; error_log /www/spzh18/test.comm.error.log; }

然而浏览器访问aaa.com出现502错误,不能访问502 bad gateway,但是在服务器里curl http://127.0.0.1:8088可以成功

查看nginx日志如下

2021/06/07 01:45:16 [error] 19#19: *1 connect() failed (111: Connection refused) while connecting to upstream, client: 110.57.158.0, server: aaa.com, request: "GET / HTTP/1.1", upstream: "http://127.0.0.1:8088/", host: "aaa.com" 

链接拒绝,网络不同

后面想到我nginx在docker容器里面,127.0.0.1访问不到宿主机,用workerman的容器IP才能访问到

所以修改代理ip如下

upstream spzh18 { server 172.17.0.7:8088; }

重启nginx后,成功

原文链接:https://blog.csdn.net/flysnownet/article/details/117652734

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享