Nginx反向代理出现错误 502 bad gateway 案例解析

场景描述

Nginx + uwsgi + flask

Flask框架写的程序,使用uwsgi启动,Nginx作为反向代理调用Flask应用。

Flask应用有些操作时间比较长,会超过1分钟,在网页端访问会出现错误: 502 bad gateway。

Nginx的错误日志中会出现错误:upstream prematurely closed connection while reading response header from upstream

错误分析

经过网上仔细搜索,产生这种错误的原因:Nginx在从Flask中获得相应数据时出现了错误,链接被关闭导致的,也就是Nginx从Flask获得数据时,没有获得正常的返回结果,链接被中断了。

解决方法

修改uwsgi的配置参数,增加下面代码

复制代码
http-timeout=300
socket-timeout=300

上面两个超时的默认值都是60秒,修改成300秒后,问题解决。真正的原因是:Nginx调用uwsgi时,uwsgi默认60秒超时,到了60秒后,uwsgi将链接断开了,Nginx就产生了错误502 bad gateway。

这两个超时的含义不一样,为了能起到作用,两个都加上了,大家可以从网上搜索两个参数的区别。

其他注意

产生类似错误很可能有其他超时参数,例如Nginx的参数

复制代码
  proxy_connect_timeout 300;
  proxy_read_timeout 300;
  proxy_send_timeout 300;

上面的参数默认值都是60,对于需要长时间的操作,都需要修改这些参数。

webouse 在此记录解决方法,方便以后查阅。

相关推荐
云飞云共享云桌面2 小时前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
chushiyunen3 小时前
langchain4j笔记、tools
笔记·python·flask
Hadoop_Liang3 小时前
使用Kubernetes Gateway API实现域名访问应用
容器·kubernetes·gateway
楠目5 小时前
Nginx 解析漏洞利用总结
nginx·网络安全
Maynor9965 小时前
我用 Codex 给自己的网站上线了一个智能体客服:从 Dify 到服务器部署,全程实战复盘
运维·服务器
worilb6 小时前
Spring Cloud 学习与实践(9):Gateway + JWT 统一鉴权
学习·spring cloud·gateway
java_cj6 小时前
深入kubectl create源码:从YAML到Pod的完整链路拆解
运维·云原生·容器·kubernetes
叫我:松哥7 小时前
基于机器学习的中文文本抑郁症风险检测系统,包括NLP与传统机器学习的抑郁症识别,准确率92%
人工智能·深度学习·机器学习·自然语言处理·flask·nlp·bootstrap
深圳恒讯7 小时前
越南服务器BGP多线和单线有什么区别?
运维·服务器
志栋智能7 小时前
超自动化运维如何提升安全合规水平?
运维·安全·自动化