重新加载与重新启动uWSGI以激活代码更改

在阅读了 uWSGI关于 reloading的文档后,我的理解是,对于使用 的应用程序lazy-apps,写入wuWSGI 的主 FIFO 应该触发所有工作程序的重新启动(从而激活 Python 代码中的更改)。

但是,这似乎对我不起作用。我需要重新启动systemd服务 ( systemctl restart myservice) 才能使代码更改生效。我误解了文档,还是我的设置有问题?

我的myservice.service文件看起来像这样:

...
ExecStart=/usr/lib/myservice/virtualenv/bin/uwsgi --ini /etc/myservice/uwsgi.ini
ExecReload=/bin/echo 'w' > /run/myservice/masterfifo
ExecStop=/bin/kill -INT $MAINPID
...

尤其是systemctl reload myservice应该写到w主设备的 FIFO。我可以从日志中systemctl status myservice看到重新加载已执行,但对 HTTP 请求的响应告诉我旧代码仍然处于活动状态。

/etc/myservice/uwsgi.ini是这样的:

[uwsgi]
processes = 16
procname-master = myservice
master-fifo = /run/myservice/masterfifo
touch-chain-reload
listen = 128

thunder-lock
reload-on-as = 4096
limit-as = 8192
max-requests = 2000

; termination options
vacuum
die-on-term

; application
chdir = /usr/lib/myservice
virtualenv = /usr/lib/myservice/virtualenv
module = myservice.uwsgi
callable = app  
master
need-app
enable-threads
lazy = True
lazy-apps = True

; logging
logto = /var/log/myservice/uwsgi.log
log-maxsize = 5242880
logdate = [%%Y/%%m/%%d %%H:%%M:%%S]
disable-logging

; stats server
stats-server = :8201
memory-report

; unix socket config (nginx->uwsgi)
socket = /run/myservice/myservice.sock
chown-socket = api
chmod-socket = 660

我正在运行2.0.19.1uWSGI的版本。

以上是重新加载与重新启动uWSGI以激活代码更改的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>