linux+kill+进程时显示没该进程号,linux kill进程没有立刻停止

前些天在执行restart脚本的时候遇到了一个奇怪的问题:

1、第一次执行进程不见了,启动失败

2、第二次重启进程成功,但是在kill的时候提示进程不存在

需要重启两次进程才能成功

查看日志文件:

第一次重启失败是因为端口被占用,那么意味着进程没有被kill掉。第二次kill提示进程不存在则是因为在第一次重启进程的时候写入了新的进程号(然后在绑定端口监听的时候发现端口被占用,进程启动失败)

接下来需要研究的是,在执行了kill之后进程为什么没有立刻被kill掉,查资料发现:

也就是说执行kill以后,信号被放在了pending对列中,下一次cpu调度这个进程耗时较长。

查看了一下,系统600多个进程,所以暂时的处理办法是先sleep 0.1s,然后再执行kill命令

参考:

附:重启脚本

#!/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..."

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值