我有生产单位,其中java进程已成为僵尸并保持在那里一段时间.如果重启设备,则会清除它.但是,该单元未重新启动,另一个Java进程已启动并正在运行.如果这个僵尸状态仍然没有清除它,是否有任何问题?它会以任何方式影响(表现还是缓慢)? 解决方法: 由于Zombie进程不会耗尽任何系统资源,因此僵尸进程不会对性能或速度产生任何影响.
注意: – 实际上,它仍然使用PID(这是一种有限的资源),并且仍然分配了进程的内核数据结构. 通常,这并不重要,但内核内存使用情况可以 在内存非常有限的系统上很重要
Problem caused by zombie process
Each zombie process retains its process ID . Linux systems have a
finite number of process IDs – 32767 by default on 32-bit
systems.If zombies are accumulating at a very quick rate ,the entire
pool of available PIDs will eventually become assigned to zombie
processes, preventing other processes from launching.
注意:在64位系统上,可以增加最大PID,请参见https://unix./a/16884/170373
然而,一些僵尸进程闲置是没有问题的 – 虽然它们确实表明他们的系统上的父进程存在错误.
说明:
当进程在Linux上死亡时,它不会立即全部从内存中删除 – 它的进程描述符保留在内存中.
进程的状态变为EXIT_ZOMBIE,并通知进程的父进程其子进程已因SIGCHLD信号而死亡.
然后,父进程应该执行wait()系统调用以读取死进程的退出状态和其他信息.这允许父进程从死进程中获取信息.调用wait()后,僵尸进程将从内存中完全删除.
这通常很快发生,因此您不会在系统上看到僵尸进程累积.但是,如果父进程没有正确编程并且从不调用wait(),那么它的僵尸孩子会在内存中留下来直到它们被清理干净.
解析度:
你不能杀死僵尸进程,因为你可以使用SIGKILL信号杀死正常进程 – 僵尸进程已经死了.
杀死僵尸的一种方法是将SIGCHLD信号发送给父进程.此信号告诉父进程执行wait()系统调用并清理其僵尸子进程.使用kill命令发送信号,将下面命令中的pid替换为父进程的PID:
kill -s SIGCHLD pid
当创建僵尸的进程结束时,init继承僵尸进程并成为他们的新父进程. (init是在启动时在Linux上启动的第一个进程,并被分配了PID 1.)
注意: – 从Linux 3.4开始,进程可以使用PR_SET_CHILD_SUBREAPER选项发出prctl()系统调用,因此它们(而不是进程#1)将成为其孤立后代进程的父进程.参见:https://unix./a/177361/5132
然后INIT执行wait()系统调用来清理它的僵尸子节点,因此init将对僵尸进行简短的工作.关闭后,您可以重新启动父进程. 来源:https://www./content-3-383401.html
|