为什么我不能使用systemd停止我的Mojo应用程序?

时间:2018-01-13 16:44:39

标签: perl systemd mojolicious

我可以通过systemd启动我的Mojo应用程序而不会出现任何问题,但我无法以相同的方式停止或重新启动它。我已经挖掘了我的配置主要来自http://mojolicious.org/perldoc/Mojolicious/Guides/Cookbook#Pre-forking的Mojo文档:

[Unit]
Description=ldsquiz.org
After=network.target

[Service]
Type=simple
Restart=always
RestartSec=30
ExecStart=/home/sites/www.ldsquiz.org/checkout/bin/carton-exec app.pl prefork -m production -l http://*:5103
KillMode=process
User=ldsquiz
Group=ldsquiz
SyslogIdentifier=ldsquiz-org

[Install]
WantedBy=multi-user.target 

如果我通过sudo service ldsquiz-org stop停止,则系统日志会显示Jan 13 16:37:48 web-hosting systemd[1]: Stopped ldsquiz.org.,但进程仍在运行。

restart通过systemd看起来像我期望的那样,因为由于关闭失败,listen套接字仍在使用中:

Jan 13 16:39:13 web-hosting systemd[1]: Stopped ldsquiz.org.
Jan 13 16:39:13 web-hosting systemd[1]: Started ldsquiz.org.
Jan 13 16:39:14 web-hosting ldsquiz-org[20353]: Can't create listen socket: Address already in use at 
/home/sites/www.ldsquiz.org/checkout/local/lib/perl5/Mojo/IOLoop.pm line 126.
Jan 13 16:39:14 web-hosting systemd[1]: ldsquiz-org.service: Main process exited, code=exited, status=98/n/a
Jan 13 16:39:14 web-hosting systemd[1]: ldsquiz-org.service: Unit entered failed state.
Jan 13 16:39:14 web-hosting systemd[1]: ldsquiz-org.service: Failed with result 'exit-code'.
Jan 13 16:39:15 web-hosting ldsquiz-org[16886]: [Sat Jan 13 16:39:15 2018] [info] Creating process id file "/tmp/prefork.pid"

我在这里缺少什么?

1 个答案:

答案 0 :(得分:8)

显然, Mojolicious Cookbook w.r.t中有一个缺陷。预备和系统单位。

They say

  

要使用systemd管理预分支Web服务器,您可以使用   像这样的单位配置文件。

[Unit]
Description=My Mojolicious application
After=network.target

[Service]
Type=simple
ExecStart=/home/sri/myapp/script/my_app prefork -m production -l http://*:8080
KillMode=process

[Install]
WantedBy=multi-user.target

KillMode=process设置错误,需要替换为KillMode=control-group - 这是默认设置,因此我们可以完全放弃。

KillMode docs说:

  

如果设置为control-group,则控制组中的所有剩余进程   单位停止时将被杀(对于服务:停止后   执行命令,如ExecStop =)所配置。 如果设置为   process,只有主进程本身被杀死。

(强调我的)

因此:

[Unit]
Description=My Mojolicious application
After=network.target

[Service]
Type=simple
ExecStart=/home/sri/myapp/script/my_app prefork -m production -l http://*:8080
KillMode=control-group

[Install]
WantedBy=multi-user.target

请注意,KillMode=control-group可以省略,因为此设置是默认设置。

参考文献: