linux部署程序
场景:项目启动是按照启动脚本进行启动的,启动脚本是start.sh
现象:启动脚本启动之后,有些请求总是请求不过来,而且重启服务,使用kill -9 pid根本杀不死。
分析:当时毫无头绪,上网搜索发现可以查看一下程序是否存在僵尸进程。
僵尸进程产生的原因是由于子进程被杀死了,但是父进程还活着,所以这个子进程就在进程表中占用一个位置,而且无法死掉。
僵尸进程: 是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。如果父进程先退出 ,子进程被init接管,子进程退出后init会回收其占用的相关资源
原因:
子进程被直接杀死
子进程无法正常关闭
查看僵尸进程命令:ps -ef|grep defunct//可以查看当前所有的僵尸进程
杀死僵尸进程的方式:1、重启服务器 或者2、kill -9 父进程 kill -9 子进程。
怎么避免产生僵尸进程呢?
1、子进程结束后,父进程收到了它结束的消息,并调用了wait回收了子进程的资源。从而避免了僵尸进程的产生。
本系统执行sh start.sh脚本中,最后有一个tail -f nohut.out直接查看启动日志的命令。以至于项目启动完成后,项目的父进程变成了sh start.sh进程。所以每次停止服务都必须杀掉父进程才能停止掉子进程。(父进程停止的时候,会检查该父进程下所有的子进程,把子进程交给init进程来接管,父进程1)