nginx实现反向代理出现502的问题解决
1. 出现原因
这里我是用的docker容器来进行nginx的启动的,在我们用nginx的配置进行反向代理的时候,有时候访问反向代理的url会出现Bad Gateway也就是坏请求,这里无非就是几种情况:
这里是我的代理代码:
location /base { proxy_pass http://localhost:8800; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; }
1.1. 防火墙拦截了端口
我们在宿主机也就是服务器里面执行我们的资源路径:
curl http://1.92.141.215:8800/captchaImage
可以看到是能访问得到的
然后进入容器执行这行命令: curl http://1.92.141.215:8800/captchaImage命令
docker exec -it nginx bash
我的也是可以访问的,说明我的端口80和8800都是开放的,如果你的在nginx访问不到 说明端口没有开放,可以关闭防火墙或者开放安全组的端口
1.1.1. 使用 iptables
假设您要开放 TCP 端口 80
sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT sudo iptables-save
1.1.2. 使用 firewall-cmd(适用于 CentOS/RHEL 7+)
sudo firewall-cmd --zone=public --add-port=80/tcp --permanent sudo firewall-cmd --reload
通过这样你就可以正常访问到代理的资源路径了
1.2. docker容器中的ip和宿主机ip不一致
因为在docker容器里,我们映射了代理到本机的localhost上面,但是容器的IP和宿主机的IP是不一样的,所以无法通过127.0.0.1去进行代理,必须把localhost换成服务器的IP。
location /base { proxy_pass http://1.92.141.215:8800; # 将localhost换成服务器ip proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; }
这样我们通过代理的url去访问我们的服务器资源就可以成功访问了。
到此这篇关于nginx实现反向代理出现502的问题解决的文章就介绍到这了,更多相关nginx反向代理502内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Nginx配置SSL证书出现PEM_read_bio_PrivateKey() failed错误解决
在配置GoDaddy的SSL证书并启动Nginx时,可能遇到由于证书密钥文件编码问题导致的启动失败,具体表现为nginx报错:PEM_read_bio_PrivateKey() failed,本文就来介绍一下,感兴趣的可以了解学习2024-10-10SQL操作Pandas DataFrame的三种方式示例详解
这篇文章主要为大家介绍了SQL操作Pandas DataFrame的三种方式示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-08-08
最新评论