• linux kill进程没有立刻停止


    前些天在执行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..." 
  • 相关阅读:
    Windows10 搭建 ElasticSearch 集群服务
    python开发目录
    nohup命令使用
    shell脚本概述
    关于ELK
    keepalived+DR
    shell脚本中awk的用法
    shell脚本中sed的用法
    shell脚本中grep的用法
    shell检测入侵与邮件报警
  • 原文地址:https://www.cnblogs.com/nerrissa/p/12030109.html
Copyright © 2020-2023  润新知