前些天在执行restart脚本的时候遇到了一个奇怪的问题:
1、第一次执行进程不见了,启动失败
2、第二次重启进程成功,但是在kill的时候提示进程不存在
需要重启两次进程才能成功
查看日志文件:
第一次重启失败是因为端口被占用,那么意味着进程没有被kill掉。第二次kill提示进程不存在则是因为
在第一次重启进程的时候写入了新的进程号(然后在绑定端口监听的时候发现端口被占用,进程启动失败)
接下来需要研究的是,在执行了kill之后进程为什么没有立刻被kill掉,查资料发现:
也就是说执行kill以后,信号被放在了pending对列中,下一次cpu调度这个进程耗时较长。
查看了一下,系统600多个进程,所以暂时的处理办法是先sleep 0.1s,然后再执行kill命令
参考:
1、当执行kill -9 PID时系统发生了什么
2、Linux进程状态:D
附:重启脚本
#!/bin/bash BASEDIR=$(cd "$(dirname "$0")";pwd) PID=./bin/process.pid # kill server if [ -e "$PID" ]; then cat "${BASEDIR}"/bin/process.pid | xargs kill -9 sleep 0.1 rm -rf ${BASEDIR}/bin/process.pid echo "stop process success..." fi mkdir -p ${BASEDIR}/log # start server as daemon cd ${BASEDIR}/bin chmod +x ./process nohup ./** >> ${BASEDIR}/log/out.log 2>&1 & echo "restart process server success..."