docker里启动了nginx容器,然后配置好了前端页面,后端服务在宿主机里启动运行,页面能正常预览,但是反向代理请求后端的时候报502
使用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
然后还是不通,还是报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--------------通!!!!!