解决docker nginx 502错误 connect() failed (111: Connection refused) while connecting to upstream

  场景

docker里启动了nginx容器,然后配置好了前端页面,后端服务在宿主机里启动运行,页面能正常预览,但是反向代理请求后端的时候报502,宿主机的wlan ip是192.168.1.106,宿主机docker网桥ip是172.17.0.1

若服务器是网线连接的则服务器的ip在eth0看,因为我用的是wifi所以在wlan有ip

 

nginx的配置

使用docker部署Nginx反向代理报502错误

原因

使用docker部署时,127.0.0.1指向的是docker容器的ip

我们先查看nginx容器里的ip是多少

docker inspect nginx

可以看到网关是172.17.0.1 ,ip地址是172.17.0.4 

然后再来查看宿主机的docker0网桥下的ip是多少

所以要在nginx的配置文件里配置应改为这样,改成宿主机在docker0网桥下分配的ip:172.17.0.1或者宿主机的真实ip:192.168.1.106(非公网)

原理:当安装了docker,宿主机会和docker新建一个叫docker0的网桥,用于宿主机和docker容器进行通信。每个docker容器都有一个docker0网桥里分配的ip。

然后还是不通,还是报502,于是进行以下排查思路

1.宿主机和docker里的容器是否能通信,ping通ip

宿主机能ping通docker里的nginx容器

docker里的nginx容器也能ping通宿主机在docker0网桥分配的ip 

若容器无ping命令则可以

#这个命令的作用是:同步 /etc/apt/sources.list 和 /etc/apt/sources.list.d 中列出的源的索引,这样才能获取到最新的软件包。
apt-get update
2)等更新完毕以后再敲命令即可。
apt-get install iputils-ping

2.进行telnet端口检测是否端口能通信

docker里的nginx容器对宿主机在docker0网桥分配的ip +后端启动的服务端口是否能通信

发现8089端口和6379端口都无法通信,只有80端口能通信

若容器无telnet则进行安装即可

apt-get install telnet

于是查看宿主机防火墙开放的端口

发现开放了80端口,那更加确定了8089端口由于防火墙没开通的情况下,导致容器无法与宿主机进行通信

于是添加了8089端口后

继续telnet--------------通!!!!!

  • 12
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 11
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值