前些天在执行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..." 

最新文章

  1. 解决升级PHP7后 微信公众号收不到消息
  2. About_PHP读写文件
  3. Cisco ASA 配置案例---anyconnect拨通后所有流量从服务器端出去
  4. mybatis——使用mapper代理开发方式
  5. LeetCode 01 Two Sum swift
  6. HTML5 Input 类型
  7. 解决tableViewCell分割线不到左边界的问题
  8. $.ajax返回的JSON格式的数据后无法执行success的解决方法
  9. Yii javascript 的结合 账号禁用 激活 的设置。
  10. ExtJs自学教程(1):一切从API開始
  11. uboot中的mmc命令
  12. git push error: RPC failed; result=56, HTTP code = 0 ,the remote end hung up unexpectedly
  13. Servlet实现后台分页查询
  14. TypeError: Error #1034: 强制转换类型失败:无法将 flash.events::MouseEvent@73b7cc1 转换为 mx.events.ItemClickEvent。
  15. Nginx之(二)Nginx安装
  16. python 面向对象编程(初级篇)
  17. Ajax状态值及状态码整理
  18. 利用ngx_python模块嵌入到Python脚本
  19. js alert换行
  20. capwap学习笔记——初识capwap(一)

热门文章

  1. [Python]h5py/__init__.py:36:
  2. // 生成modbus CRC16数据
  3. ThreeJS 阴影条纹BUG
  4. 12 Spring Data JPA:springDataJpa的运行原理以及基本操作(上)
  5. UML-类图定义
  6. Python dict 字典 keys和values对换
  7. Django专题之ORM操作2
  8. windows安装theano和keras
  9. Intellij IDEA中mybatis-generator自动生成
  10. 11)const