V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
NGINX
NGINX Trac
3rd Party Modules
Security Advisories
CHANGES
OpenResty
ngx_lua
Tengine
在线学习资源
NGINX 开发从入门到精通
NGINX Modules
ngx_echo
chenqh
V2EX  ›  NGINX

关于 nginx upstream 遇到的一个问题

  •  
  •   chenqh · 2020-01-14 21:01:47 +08:00 · 3187 次点击
    这是一个创建于 1782 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我定义了一堆 upstream

    upstream {
    	server 127.0.0.1:1050;
        server 127.0.0.1:1051;
        server 127.0.0.1:1052;
        server 127.0.0.1:1053;
    }
    

    在我的代码里面我对错误的处理是这个样子的

    1. 设置状态为 500
    2. 返回详细的 json

    现在遇到了问题
    只要我拼命导致这种 500 的请求
    然会就会出现 502!
    难道 nginx 判断上游是不是 fail,也使用了 500
    我改成了 400 就不会 502 了

    所以问题来的, upstream 判断上游 fail 到底有哪些条件?

    12 条回复    2020-01-14 22:13:24 +08:00
    msg7086
        1
    msg7086  
       2020-01-14 21:04:29 +08:00 via Android   ❤️ 1
    5 系是服务器崩溃或者出问题。4 系是客户端有病。没记错的话是这个规范,你可以去查查状态码分类含义。
    also24
        2
    also24  
       2020-01-14 21:17:41 +08:00   ❤️ 1
    你是否配置了 proxy_next_upstream 参数?

    我翻看了一下官方文档 http://nginx.org/en/docs/http/ngx_http_upstream_module.html#max_fails
    上面写的是:
    What is considered an unsuccessful attempt is defined by the proxy_next_upstream......

    再翻看 proxy_next_upstream 的说明
    http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_next_upstream

    默认参数只有 error 和 timeout,没有包含 http_50x
    chenqh
        3
    chenqh  
    OP
       2020-01-14 21:21:43 +08:00
    @also24 我个人是没有配置的,但是我用的是 bt 的 nginx,我也不敢确保到底配没有配了
    also24
        4
    also24  
       2020-01-14 21:23:47 +08:00
    @chenqh #3
    可以自己手动加入一下这个字段来覆盖参数试试看
    Livid
        5
    Livid  
    MOD
       2020-01-14 21:24:03 +08:00   ❤️ 1
    如果是用户输入了不合法的数据,后端程序本身没有因此崩溃的话,那么应该返回的状态码是 400 Bad Request。
    also24
        6
    also24  
       2020-01-14 21:45:24 +08:00   ❤️ 1
    @chenqh #3
    才反映过来你说的 bt 是宝塔啊,我找了个宝塔的服翻了下配置,确实是宝塔加了这一句

    它的 nginx 配置文件在:
    /www/server/nginx/conf/nginx.conf

    里面引用了:
    /www/server/nginx/conf/proxy.conf

    在这个文件里,配置了:
    proxy_next_upstream error timeout invalid_header http_500 http_503 http_404;
    chenqh
        7
    chenqh  
    OP
       2020-01-14 21:53:55 +08:00
    @also24 我刚刚居然没有找到
    also24
        8
    also24  
       2020-01-14 21:55:22 +08:00
    @chenqh #7
    其实不管它有没有加,自己在相应的 Server 字段里加好覆盖一下应该也是没问题的~
    chenqh
        9
    chenqh  
    OP
       2020-01-14 21:58:45 +08:00
    @also24 之前完全不会,之前只会配置 upstream, rewrite 都是今年学的
    wangyzj
        10
    wangyzj  
       2020-01-14 22:07:15 +08:00
    全 200
    然后用自定义 code 来区分是我的习惯啊
    chenqh
        11
    chenqh  
    OP
       2020-01-14 22:09:40 +08:00
    @wangyzj 但是你这个样子有个问题,看浏览器监听的时候,不能快速知道你的东西错了
    wangyzj
        12
    wangyzj  
       2020-01-14 22:13:24 +08:00
    @chenqh 主要还是个人习惯吧
    我之所以这么做是因为懒,还有就是因为我会也会把极严重问题改成 500,其他的 200,要不然总是红色我心脏受不了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1588 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 17:05 · PVG 01:05 · LAX 09:05 · JFK 12:05
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.