僵尸进程不能被直接清理,需父进程调用wait()回收;产生于子进程先结束而父进程未读取其退出状态时;可通过ps或top识别Z状态进程;解决方法是唤醒父进程、重启服务或终止父进程使其被init收养;预防关键在于父进程主动处理SIGCHLD信号。

僵尸进程本身不能被直接“清理”,因为它的资源已经释放,只留下一个进程表项。真正要做的,是让它的父进程调用 wait() 或 waitpid() 来读取退出状态,从而让内核回收该表项。如果父进程不配合,就得考虑终止父进程或重启服务。
僵尸进程是怎么产生的
当子进程先于父进程结束时,内核不会立即删除其进程描述符,而是保留少量信息(如退出码、PID),等待父进程通过 wait 系列系统调用获取。这段时间内,子进程就处于 Z(zombie)状态——它不占 CPU、不占内存,但仍在进程表中占一个位置。
常见诱因包括:
- 父进程写法有缺陷,忘记调用 wait()
- 父进程忙于其他任务,长期未处理子进程退出信号(如 SIGCHLD)
- 父进程已崩溃或被 kill,但子进程仍残留(此时 init 进程会收养,一般很快回收;若未被收养,可能卡住)
如何识别当前的僵尸进程
用 ps aux | grep 'Z' 或 ps aux | awk '$8 ~ /Z/ {print}' 查看状态为 Z 的进程。输出中 PPID 列就是它的父进程 PID。
也可以用 top 命令观察:底部会显示类似 1 zombie 的提示;或者在 htop 中按 F4 搜索 Z 状态。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~