场景
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--------------通!!!!!文章来源:https://www.toymoban.com/news/detail-447167.html
文章来源地址https://www.toymoban.com/news/detail-447167.html
到了这里,关于解决docker nginx 502错误 connect() failed (111: Connection refused) while connecting to upstream的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!