前些天在执行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..." 
posted on 2019-12-12 16:45  妞溜溜  阅读(2559)  评论(0编辑  收藏  举报