一、我的问题场景:(有的人可能是场景四,见最下面)
//1. nginx重启,查看lsof -i:80 有 pid进程nginx -s reload //2. nginx关闭,查看lsof -i:80 无 pid进程nginx -s stop //3. 再次nginx重启,报错nginx -s relaod
二、报错信息:
三、思考:
/var/run/nginx.pid 是干嘛用的?
此文件夹包含描述系统启动以来系统信息的数据。此文件夹下的文件必须在启动过程初期清除(删除或归零)。程序可以在/var/run下有自己的子文件夹。原先放在/etc下的进程标识(PID)文件必须放在/var/run里面。PID文件的命名惯例是program-name.pid。所以,nginx的PID文件名为/var/run/nginx.pid。见引用
为什么会报错
reopen是在nginx启动的情况给做分割日志用的,reload也是在nginx启动的情况下做平滑重启的,他们都依赖于 nginx 进程存在的情况下,
nginx被停止时,var/run/nginx.pid被删除了。 而reopen和reload命令需要通过nginx.pid获取进程号,会去找var/run.nginx.pid,如果不存在,就报错了。
reopen 和 reload 并不是字面上启动或打开的意思。
解决办法
真正的启动命令是:nginx或者nginx -c指定目录的配置文件nginx.conf,
查看进程存在即表明启动成功,之后再调用reload和reopen就不会报错了。
四、我之前遇到的另外一个场景:【补充】
描述:重启虚拟机后,再次重启nginx会报错问题描述:和 上面提到的原因一样,nginx.pid文件被删除了解决办法:
(1)在nginx执行文件目录下执行
cd /usr/local/sbinnginx
(2)见引用(第二种方法我试过,是OK的)