nginx 后端接口超时

1,928 阅读1分钟

问题描述

今天碰到 nginx 报时间超时的错误,这个接口是新加的,涉及到大量的计算,运行时间比较长,但是在开发过程中调试的时候是没有问题的。

先介绍一下服务的架构,所有的请求都是直接发送到 nginx 上,再有 nginx 根据路由来转发到不同的服务上,此接口对应的服务是一个由 gunicorn 启动的 Flask 项目。

排查过程

nginx

先查看nginx配置

# nginx.conf 文件中
http {
    ...
    server{
        listen: 8078;
        ...
        location /api {
            proxy_pass 服务地址;
            # proxy_read_timeout 是用来设置超时时间的,单位为 s,默认是 60 s
            proxy_read_timeout 300;
        }
    }
}

此处介绍一些 nginx 有关于超时设置的配置

proxy_connect_timeout : 后端服务器连接的超时时间_发起握手等候响应超时时间

proxy_read_timeout: 连接成功后_等候后端服务器响应时间_其实已经进入后端的排队之中等候处理(也可以说是后端服务器处理请求的时间)

proxy_send_timeout : 后端服务器数据回传时间_就是在规定时间之内后端服务器必须传完所有的数据

但是设置完成后,依然报超时错误。继续排查gunicorn。

gunicorn

[...]$ vim gunicorn.conf
...
timeout = 60
...

是因为 gunicorn 启动时,设置了超时时间为 60,将此处修改为 300,接口正常工作。