当前位置: 代码网 > 手机>品牌>手机系统 > nginx实现反向代理出现502的问题解决

nginx实现反向代理出现502的问题解决

2024年08月12日 手机系统 我要评论
1. 出现原因这里我是用的docker容器来进行nginx的启动的,在我们用nginx的配置进行反向代理的时候,有时候访问反向代理的url会出现bad gateway也就是坏请求,这里无非就是几种情况

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内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com