A-A+

出现nginx.service: Failed to parse PID如何解决?

2023年04月25日 VPS评价 等您评论

很久以前用Apache,后来偷懒就用Nginx了,毕竟轻量也够用。但是在某些机子(大概率和性能有关)上使用systemctl status nginx查看Nginx状态的时候,会出现以下报错内容:

nginx.service: Failed to parse PID from file /run/nginx.pid: Invalid argument

此报错的根源在于Nginx和systemd抢夺资源,systemd作为进程守护会读取PIDFile以实现在Nginx停止后删除PIDFile,但是Nginx启动需要时间,systemd在nginx完成启动前就去读取,从而导致了这个报错。处理方法也很简单,让systemd在执行ExecStart后等待一段时间(比如1秒钟)即可。

首先,打开/usr/lib/systemd/system/nginx.service文件,将ExecStartPost=/bin/sleep 1加入到ExecStart=/usr/sbin/nginx -g 'daemon on; master_process on;'这行下面(具体代码在文末),然后依次执行systemd的重启systemctl daemon-reloadsystemctl restart nginx.service之后,就会发现一切正常了。

[Unit]    
Description=A high performance web server and a reverse proxy server    
Documentation=man:nginx(8)    
After=network.target nss-lookup.target
    
[Service]    
Type=forking    
PIDFile=/run/nginx.pid    
ExecStartPre=/usr/sbin/nginx -t -q -g 'daemon on; master_process on;'    
ExecStart=/usr/sbin/nginx -g 'daemon on; master_process on;'    
ExecStartPost=/bin/sleep 1    
ExecReload=/usr/sbin/nginx -g 'daemon on; master_process on;' -s reload    
ExecStop=-/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /run/nginx.pid    
TimeoutStopSec=5    
KillMode=mixed
    
[Install]    
WantedBy=multi-user.target

给我留言