如何在 Linux 上杀死一个僵尸进程

系统 Linux
这里有一个和 Unix 纪元一样古老的故事。自从有了 C 和 Unix,以及(后来的)Linux,我们就有了“僵尸”。具体来说,有一些进程被标记为“僵尸进程”。一些人误解它,另一些人忽视它,而它对我们许多人试图 “杀死” 这些进程的努力免疫,没有什么成效。这是为什么呢?

[[432539]]

要杀死一个僵尸进程,你必须从进程列表中删除其名称。

这里有一个和 Unix 纪元一样古老的故事。自从有了 C 和 Unix,以及(后来的)Linux,我们就有了“僵尸zombie”。具体来说,有一些进程被标记为“僵尸进程zombie process”。一些人误解它,另一些人忽视它,而它对我们许多人试图 “杀死” 这些进程的努力免疫,没有什么成效。这是为什么呢?

Linux 中的进程是什么?

这一切始于执行 Linux 中的一个程序时,当它被执行时,它的运行实例被称为进程。你可以用 ps 命令 查看你的 Linux 环境中的所有进程:

  1. $ ps -ax
  2.         PID TTY         STAT   TIME COMMAND
  3.         1 ?     Ss      0:01 /usr/lib/systemd/systemd rhgb --switched-root --sys
  4.         2 ?     S       0:00 [kthreadd]
  5.         3 ?     I<      0:00 [rcu_gp]
  6.         4 ?     I<      0:00 [rcu_par_gp]

有时一个进程启动另一个进程,使第一个进程成为第二个进程的父进程。pstree 命令是一个很好的工具,可以让你看到系统中进程的“家谱”:

  1. $ pstree -psn
  2. systemd(1)─┬─systemd-journal(952)
  3.         ├─systemd-udevd(963)
  4.         ├─systemd-oomd(1137)
  5.         ├─systemd-resolve(1138)
  6.         ├─systemd-userdbd(1139)─┬─systemd-userwor(12707)
  7.                             ├─systemd-userwor(12714)
  8.                             └─systemd-userwor(12715)
  9.         ├─auditd(1140)───{auditd}(1141)
  10.         ├─dbus-broker-lau(1164)───dbus-broker(1165)
  11.         ├─avahi-daemon(1166)───avahi-daemon(1196)
  12.         ├─bluetoothd(1167)

每个进程在系统中都会被分配一个编号。进程编号(PID)1 被分配给启动过程中执行的第一个进程,PID 1 之后的每一个进程都是它的子孙。PID 1 进程是初始化进程,在大多数新版本的 Linux 中,它只是一个指向 systemd 程序的符号链接。

用 kill 命令结束一个进程

你可以用 kill 命令来终止 Linux 系统中的进程。尽管名字叫 “杀死”,但 kill 命令和其他一些命令,如 pkill 和 killall,都是为向一个或多个进程发送信号而编写/设计的。当没有指定信号时,它发送的默认信号是 SIGTERM 信号,以终止进程。

当一个父进程死亡或被杀死,而其子进程没有跟随其父进程的死亡,我们称该进程为“孤儿进程orphan process”。

如何杀死一个僵尸进程

另一方面,僵尸进程是不能被“杀死”的!你可能会问为什么?因为它们已经死了!

每一个子进程,当被终止时,都会成为一个僵尸进程,然后被父进程删除。当进程退出并释放它所使用的资源时,它的名字仍然在操作系统的进程表中。这时,父进程的工作就是把它的名字从进程表中删除。如果没有删除,我们就有了僵尸进程,它不再是一个真正的进程,而只是操作系统进程表上的一个条目。

这就是为什么试图对一个失效的defunct(僵尸)进程执行 “杀死” 命令,即使使用 -9SIGKILL)选项也不起作用,因为没有什么可以杀死的。

因此,要杀死一个僵尸进程,比如从进程列表(进程表)中删除其名称,你必须杀死其父进程。例如,如果 PID 5878 是一个僵尸进程,而它的父进程是 PID 4809,那么要杀死僵尸进程(5878),就必须结束父进程(4809):

  1. $ sudo kill -9 4809  # 4809 是父进程,而非僵尸

我对僵尸的最后一句警告:在杀死父进程时要非常小心。如果一个进程的父进程是 PID 1,而你杀了它,你就会重新启动自己!

而这将是一个更可怕的故事! 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2022-12-12 11:14:06

LinuxID

2024-02-05 18:23:23

父进程应用程序程序

2019-05-09 08:00:14

Linux服务器安全僵尸网络

2017-05-27 14:45:04

Linux命令进程

2015-09-17 13:26:56

线程数进程Linux

2016-07-18 10:51:19

操作系统LinuxWindows

2021-11-15 10:35:46

Python线程代码

2023-11-26 18:31:41

Linux信号

2022-08-14 08:29:21

npmNode

2019-09-10 09:12:54

2019-02-25 09:50:25

Linux命令行僵尸进程

2019-08-12 13:45:26

GithubGit开源

2014-05-20 09:59:27

Mnitrix轻型监控系统系统管理员

2016-12-07 17:45:44

Linux文件

2018-01-30 12:18:08

Linux储存器USB设备

2020-12-21 20:25:24

UbuntuDebian LinuC 程序

2018-09-17 11:35:44

Linux软件包命令

2017-12-15 09:40:47

Linux僵尸进程

2017-02-10 20:00:17

Linux共享目录命令

2021-10-25 12:23:06

Linux僵尸进程
点赞
收藏

51CTO技术栈公众号