解决启动 gunicorn 时候异常自动重启问题

问题

首先我的 flask 服务在没有使用 gunicorn 的情况下是可以正常提供服务的,在使用了 guniorn 之后遇到了以下的坑。我的服务启动需要加载很多东西,需要一段时间,使用下面命令进行启动,开多个进程:

bash 复制代码
gunicorn -c gunicorn.py test:app

启动之后正常运行,但是执行到中间就会自己中断然后重新进行启动,而且一直在重复这个重启过程,我将 gunicorn_error.log 的内容打印出来,如下:

less 复制代码
2023-10-31 15:16:07 +0800] [798] [ERROR] Worker (pid:1062) was sent SIGKILL! Perhaps out of memory?
[2023-10-31 15:16:07 +0800] [798] [ERROR] Worker (pid:1047) was sent SIGKILL! Perhaps out of memory?

看到有 out of memory 我起初以为是 OOM 的问题,空出足够的内容,重新启动 gunicorn -c gunicorn.py test:app ,然而仍然是上面的问题,于是我将 worker 的数量将为 1 去重新启动,仍然是上面的问题。

解决

我经过打印日志计时发现每次在正常运行后的 30s 左右会自己重启,于是我突然灵机一动去查看 gunicorn 的默认配置(见参考的链接),果然发现了一个和 30s 相关的参数 --timeout ,

这个参数表示的就是超过默认时间 30s 后工作将被杀掉并重新启动,和我遇到的现象一摸一样。于是我在配置文件 gunicorn.py 中将其改为了 60s ,如下:

ini 复制代码
timeout = 60

保存文件后,然后重新启动,果然可以正常运行了。

tnnd,差点就被日志误导了。

参考

www.jiebaiyou.com/2019/12/18/...

相关推荐
闵孚龙5 小时前
动态图机制:为什么 PyTorch 调试起来更舒服
人工智能·pytorch·python
chushiyunen5 小时前
langchain4j笔记、tools
笔记·python·flask
程序员三藏6 小时前
Web自动化测试详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
在放️7 小时前
Python 爬虫 · 第三方代理接入与合规使用
开发语言·爬虫·python
财经资讯数据_灵砚智能7 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年6月14日
大数据·人工智能·python·ai·信息可视化·自然语言处理·灵砚智能
叫我:松哥9 小时前
基于机器学习的中文文本抑郁症风险检测系统,包括NLP与传统机器学习的抑郁症识别,准确率92%
人工智能·深度学习·机器学习·自然语言处理·flask·nlp·bootstrap
JOJO数据科学9 小时前
JupyterLab Electron 鸿蒙 PC 适配全记录:从 Python 原生崩溃到 node-static 本地工作台
python·electron·harmonyos
xufengzhu10 小时前
第三方 Python 库 redis-py + hiredis 的使用
开发语言·redis·python
llxxyy卢10 小时前
polar夏季赛部分题目
开发语言·python
闵孚龙10 小时前
PyTorch 系列 之 nn.Module:所有模型的骨架
人工智能·pytorch·python