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 在此记录解决方法,方便以后查阅。

相关推荐
羊锦磊几秒前
AI 助手大模型---阿里云创建AI应用
运维·服务器·数据库
小北方城市网1 分钟前
Elasticsearch 分布式检索生产级优化:从索引设计到查询性能
java·大数据·运维·redis·分布式·elasticsearch·搜索引擎
周杰伦的稻香7 分钟前
Debian 9 (Stretch)仓库无法使用
运维·debian
嵌入式-老费9 分钟前
Linux camera驱动开发(开篇)
linux·运维·驱动开发
岁岁种桃花儿11 分钟前
企业级K8s集群两层Nginx架构实战:Ingress Controller独立部署与动态伸缩全解析
nginx·架构·kubernetes
倔强菜鸟14 分钟前
2026.1.27--负载均衡
运维·负载均衡
市安18 分钟前
负载均衡入门:HAProxy 双 Web 节点集群配置与验证
linux·运维·服务器·网络·nginx·负载均衡·haproxy
qq_3129201120 分钟前
Nginx HTTPS配置与证书自动续期:Let‘s Encrypt实战
运维·nginx·https
一直跑26 分钟前
通过所里的服务器连接到组里的服务器,然后可视化组里的文件和代码,并修改等操作(VScode/vscode/mobaxterm)
linux·运维·服务器
mobai71 小时前
Ubuntu环境上安装NTP服务
linux·运维·ubuntu