问题描述
今天碰到 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,接口正常工作。