Docker系列 | 您所在的位置:网站首页 › 502报错解决方案 › Docker系列 |
简介
本文介绍如何解决Docker部署nginx做反向代理时出现502报错的问题。 相关网址 Docker系列-网络的配置 – 自学精灵 情景说明 web程序和nginx都使用docker部署在Ubuntu web程序是8090端口 使用nginx做代理,将请求转发到web程序 web程序和nginx已经使用docker compose connect进行了网络连接nginx配置如下: events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { # 所有IPV4的地址 listen 80; # 所有IPV6的地址 listen [::]:80; server_name 192.168.5.193; client_max_body_size 20m; charset utf-8; location / { proxy_set_header HOST $host; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://itthinktank; } } upstream itthinktank { server 127.0.0.1:8090; } } 问题复现访问nginx时出现502页面: ![]() docker与docker之间的通信是通过虚拟网桥docker0实现的,需要使用docker0的ip表示本地网络,不能使用127.0.0.1。 解决方案使用docker0的ip。 1.查看docker0的ip 命令:ifconfig ![]() 2.将127.0.0.1改为docker0的ip events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { # 所有IPV4的地址 listen 80; # 所有IPV6的地址 listen [::]:80; server_name 192.168.5.193; client_max_body_size 20m; charset utf-8; location / { proxy_set_header HOST $host; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://itthinktank; } } upstream itthinktank { #server 127.0.0.1:8090; server 172.17.0.1:8090; } } |
CopyRight 2018-2019 实验室设备网 版权所有 |