python3 + gunicorn(多进程) + rq + subprocess 程序莫名 killed

2022-01-13 17:05:14 +08:00
 taomujian

用 gunicorn 部署的一个程序,队列使用 rq,每个 worker 里调用 subprocess.Popen.communicate 去执行 go 程序,日志会保存到 log 文件,然后 python 读取 log 进行处理.当 gunicorn 配置文件中设置进程为多个时,rq 的日志文件会有警告 Lock already taken - skipping run,与此同时还有一条日志是 killed,go 程序就会被终止,python 也读取不了日志.当 gunicorn 配置文件中设置进程为 1 时则没有这个问题,这是哪里出问题了?

2061 次点击
所在节点    Python
5 条回复
zhoudaiyu
2022-01-13 17:21:33 +08:00
https://github.com/rq/rq-scheduler/issues/257 可以看看这个 xd 的自问自答里面的两个 here
taomujian
2022-01-13 17:40:23 +08:00
@zhoudaiyu 看过了,并没有什么解决方法,只是说 Lock already taken - skipping run 是一个特性。。。。
corvofeng
2022-01-13 18:00:42 +08:00
killed 是不是容器内存满了, 进程被停了
taomujian
2022-01-13 18:07:20 +08:00
@corvofeng 有可能,不过运行的程序都是在主机上,只有 es,mongodb,redis 用的 docker,我把 es 切换到主机上
julyclyde
2022-01-14 12:00:38 +08:00
Killed 十有八九都是内存满。你看 dmesg 吧

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/828064

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX