为什么 PHP-FPM 需要 5 分钟才能在我的服务器上重新启动


Why does PHP-FPM take 5 minutes to restart on my server?

我正在使用默认设置的PHP-FPM。我的服务器正在运行最新的 Arch Linux。

我发出命令sudo systemctl restart php-fpm,需要五分钟才能重新启动并返回提示符。

这个问题有已知的解决方案吗?

这是由 PHP-FPM 的 systemctl 脚本的创建方式引起的。我也有同样的问题。这是我解决它的方法。

首先找到你的启动脚本,如果你不知道你可以做systemctl status php-fpm,你会看到类似的东西:/etc/systemd/system/php.service

现在编辑此文件,它应如下所示:

[Unit]
Description=The PHP FastCGI Process Manager
After=syslog.target network.target
[Service]
Type=notify
PIDFile=/run/php-fpm/php-fpm.pid
PrivateTmp=true
ExecStart=/usr/bin/php-fpm --nodaemonize --pid /run/php-fpm/php-fpm.pid
ExecReload=/bin/kill -USR2 $MAINPID
[Install]
WantedBy=multi-user.target

将其更改为:

[Unit]
Description=The PHP FastCGI Process Manager
After=syslog.target network.target
[Service]
ExecStart=/usr/bin/php-fpm --nodaemonize
ExecReload=/bin/kill -HUP $MAINPID
Restart=always
[Install]
WantedBy=multi-user.target

一个文件被更改运行此命令刷新 systemctl -> systemctl daemon-reload

现在重新启动 FPM。我建议在更改此文件之前先关闭 FPM。进行更改后,FPM将立即启动/停止/重新启动。

现在我还不知道为什么,但有时在我进行此更改后,似乎 FPM 仍然需要很长时间才能启动/停止/重新启动。所以我只是继续重新启动我的机器,从那时起它就立即发生了。所以我猜有些东西挂起了,我还没有找到,但重新启动解决了这个问题。我知道你不应该重新启动,但在我找到它到底挂在哪里之前,这暂时解决了问题。