nginx报错 502 no live upstreams while connecting to upstream

本文记录了在使用Nginx进行负载均衡时遇到的问题及解决方案,特别是针对WebSocket连接频繁报错的情况,通过调整proxy_next_upstream配置项成功解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天因业务需求,需要用nginx 做负载均衡,于是从网上找了一些资料,搞定了这个功能。贴上我最初的配置信息

upstream websocket {
        server 192.168.2.124:12307  max_fails=5 fail_timeout=60s;
        server 192.168.2.123:12307 max_fails=5 fail_timeout=60s;
      }
    server {
        listen       80;
        server_name  192.168.2.124;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
           proxy_pass http://websocket;
           proxy_next_upstream error timeout invalid_header http_500 http_502 http_503;
            proxy_set_header Host $host;
            proxy_http_version 1.1;
            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 https;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
            proxy_set_header Origin "";
            proxy_redirect off;
            proxy_read_timeout 600s;
        }
}

但是在正式使用的过程中,发现每隔几次的访问,nginx 都会报错一次。错误页面如下

从网上找了各种资料,大概都是一个人的文章,被翻来覆去的抄,完全不能解决问题。

最后在一个网站的回答中找到了一条有用信息,说去除 proxy_next_upstream 后面 http_500 就好了,然后试了一下,果然解决了这个问题。具体原因暂未清楚,暂且纪录解决办法,待以后有空再仔细研究这个问题。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值