gpt4 book ai didi

python - uwsgi 在作为 systemd 服务运行时损坏管道

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:47:00 27 4
gpt4 key购买 nike

我正在使用 python 2.7.11 在 conda 虚拟环境中运行 uwsgi/flask python 应用程序。

我正在从 CentOS 6 迁移到 CentOS 7,并希望利用 systemd 将我的应用程序作为服务运行。如果我手动调用我的应用程序的启动脚本 (sh start-foo.sh),一切(配置和代码)都可以正常工作,但是当我尝试将其作为系统服务启动时(sudo systemctl foo start) 它启动应用程序但随后立即失败并出现以下错误:

WSGI app 0 (mountpoint='') ready in 8 seconds on interpreter 0x14c38d0 pid: 3504 (default app)
mountpoint already configured. skip.
*** uWSGI is running in multiple interpreter mode ***
spawned uWSGI master process (pid: 3504)
emperor_notify_ready()/write(): Broken pipe [core/emperor.c line 2463]
VACUUM: pidfile removed.

这是我的 systemd 单元文件:

[Unit]
Description=foo

[Service]
ExecStart=/bin/bash /app/foo/bin/start-foo.sh
ExecStop=/bin/bash /app/foo/bin/stop-foo.sh

[Install]
WantedBy=multi-user.target

不确定是否有必要,但这是我的 uwsgi emperor 和 vassal 配置:

皇帝

[uwsgi]
emperor = /app/foo/conf/vassals/
daemonize = /var/log/foo/emperor.log

封臣

[uwsgi]
http-timeout = 500
chdir = /app/foo/scripts
pidfile = /app/foo/scripts/foo.pid
#socket = /app/foo/scripts/foo.soc
http = :8888
wsgi-file = /app/foo/scripts/foo.py
master = 1
processes = %(%k * 2)
threads = 1
module = foo
callable = app
vacuum = True
daemonize = /var/log/foo/uwsgi.log

我尝试用谷歌搜索这个问题,但似乎找不到任何相关内容。我怀疑这与在虚拟环境中运行 uwsgi 并使用 systemctl 启动它有关。我是 systemd n00b,所以如果我在我的单元文件中做错了什么,请告诉我。

这不是阻止程序,因为我仍然可以通过手动执行脚本来启动/停止我的应用程序,但我希望能够将它作为服务运行并使用 systemd 在启动时自动启动它。

最佳答案

按照说明操作 here在 uwsgi 关于设置 systemd 服务的文档中解决了这个问题。

这是我改变的地方:

从 Emperor 和 Vassal 配置中删除了 daemonize

从上面的链接中获取单元文件并稍作修改以与我的应用程序一起使用

[Unit]
Description=uWSGI Emperor
After=syslog.target

[Service]
ExecStart=/app/foo/bin/uwsgi /app/foo/conf/emperor.ini
RuntimeDirectory=uwsgi
Restart=always
KillSignal=SIGQUIT
Type=notify
StandardError=syslog
NotifyAccess=all

[Install]
WantedBy=multi-user.target

关于python - uwsgi 在作为 systemd 服务运行时损坏管道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36017591/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com