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

  • Post author:
  • Post category:其他


场景

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

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

原理:当安装了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————–通!!!!!



版权声明:本文为qq_38623939原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。