django+uwsgi+nginx ajax get 504 Gateway Time-out解决方法

用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; 试了下没什么效果,也没理解,解决了便好先不管这个了。

原文链接:http://www.itawp.com/301.html,转载请注明出处。

1

评论0

没有账号? 注册  忘记密码?