用django+uwsgi+nginx 后端执行一个函数时间过长,导致前端Failed to load resource: the server responded with a status of 504 (Gateway Time-out)
一开始以为是ajax超时,调整了一下ajax请求的timeout时间,没有效果。看着也不像是ajax的超时返回错误。查了一下资料,发现原来是
nginx和uwsgi整合时有三个参数可以用于设置超时时间:
1.uwsgi_connect_timeout:
默认60秒,与uwsgi-server连接的超时时间,该值不能超过75秒.若在超时时间内未能成功连接则断开连接尝试
2.uwsgi_read_timeout:
默认60秒,nginx等待uwsgi进程发送响应数据的超时时间。若有需要长时间运行才能产生输出结果的uwsgi进程则需将此参数调高。若在错误日志文件中看到
upstream timed out需将此参数调高。若超过超时时间还未收到响应则nginx关闭连接
3.uwsgi_send_timeout:
默认60秒,nginx向uwsgi进程发送请求的超时时间。超时时间由两次写操作的时间间隔算,而非整个请求。若超过超时时间仍没写入动作则nginx关闭连接
另外:uwsgi自身还有一个参数harakiri,若每次请求需要花费超过该值的时间则放弃该请求处理相应的worker被收回
解决
本人用的是宝塔,在网站设置–配置文件中中添加 uwsgi_send_timeout 和 uwsgi_read_timeout项目,设置超时时间久一点。
location / {
......
uwsgi_read_timeout 120s;
uwsgi_send_timeout 120s;
......
}
网上还有一种方案,在这里设置proxy_read_timeout 150; 试了下没什么效果,也没理解,解决了便好先不管这个了。