mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-16 22:42:21 +08:00
选题[tech]: 20211031 How to kill a zombie process on Linux
sources/tech/20211031 How to kill a zombie process on Linux.md
This commit is contained in:
parent
f1aed3d81d
commit
6d09c228b5
@ -0,0 +1,93 @@
|
|||||||
|
[#]: subject: "How to kill a zombie process on Linux"
|
||||||
|
[#]: via: "https://opensource.com/article/21/10/linux-zombie-process"
|
||||||
|
[#]: author: "Anderson Silva https://opensource.com/users/ansilva"
|
||||||
|
[#]: collector: "lujun9972"
|
||||||
|
[#]: translator: " "
|
||||||
|
[#]: reviewer: " "
|
||||||
|
[#]: publisher: " "
|
||||||
|
[#]: url: " "
|
||||||
|
|
||||||
|
How to kill a zombie process on Linux
|
||||||
|
======
|
||||||
|
To kill a zombie process, you must remove its name from the process
|
||||||
|
list.
|
||||||
|
![Full moon on a hazy night][1]
|
||||||
|
|
||||||
|
Happy Halloween Open SOURCE-rers!
|
||||||
|
|
||||||
|
Here's a tale as old as _epoch_ time. Since there has been C and Unix, and (later on) Linux, we've had _zombies_. Specifically, there are processes that get marked as _a zombie process_. Misunderstood by some, ignored by others, and immune to the efforts of so many of us trying to `kill` these processes without much success. Why is that?
|
||||||
|
|
||||||
|
### What is a process in Linux?
|
||||||
|
|
||||||
|
It all begins when a program in Linux gets executed, and when it does, its running instance is called a process. You can see all processes on your Linux environment with the [`ps` command][2].
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ps -ax
|
||||||
|
PID TTY STAT TIME COMMAND
|
||||||
|
1 ? Ss 0:01 /usr/lib/systemd/systemd rhgb --switched-root --sys
|
||||||
|
2 ? S 0:00 [kthreadd]
|
||||||
|
3 ? I< 0:00 [rcu_gp]
|
||||||
|
4 ? I< 0:00 [rcu_par_gp]
|
||||||
|
```
|
||||||
|
|
||||||
|
Sometimes a process starts another process, making the first process the parent of the second. The `pstree` command is a great tool that allows you to see the processes' "genealogy" on your system.
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
$ pstree -psn
|
||||||
|
systemd(1)─┬─systemd-journal(952)
|
||||||
|
├─systemd-udevd(963)
|
||||||
|
├─systemd-oomd(1137)
|
||||||
|
├─systemd-resolve(1138)
|
||||||
|
├─systemd-userdbd(1139)─┬─systemd-userwor(12707)
|
||||||
|
│ ├─systemd-userwor(12714)
|
||||||
|
│ └─systemd-userwor(12715)
|
||||||
|
├─auditd(1140)───{auditd}(1141)
|
||||||
|
├─dbus-broker-lau(1164)───dbus-broker(1165)
|
||||||
|
├─avahi-daemon(1166)───avahi-daemon(1196)
|
||||||
|
├─bluetoothd(1167)
|
||||||
|
```
|
||||||
|
|
||||||
|
Every process gets assigned a number in the system. Process ID number 1 gets assigned to the very first process executed during the boot process, and every subsequent process after PID 1 is a descendant of it. The PID 1 process is the _init_, which on most newer versions of Linux is just a symbolic link to the `systemd` program.
|
||||||
|
|
||||||
|
### Ending a process with the kill command
|
||||||
|
|
||||||
|
You can terminate processes in a Linux system with the `kill`* _command_. *Despite the name, the `kill` command and a set of others such as `pkill` and `killall` got written/designed to send SIGNALS to one or more processes. When not specified, the default SIGNAL it sends is the SIGTERM signal to terminate the process.
|
||||||
|
|
||||||
|
When a parent process dies or gets killed, and its child process doesn't follow its parent's demise, we call that process an _orphan process_.
|
||||||
|
|
||||||
|
### How to kill a zombie process
|
||||||
|
|
||||||
|
Zombie processes, on the other hand, cannot be killed! Why might you ask? Well, because they are already dead!
|
||||||
|
|
||||||
|
Every child process, when terminated, becomes a zombie process and then removed by the parent. When the process exits its existence and releases the resources it had used, its name is still on the OS process table. It is then the parent's process job to remove its name from the process table. When that fails, we have the zombie process, which isn't really a process anymore, but just an entry on the process table of the OS.
|
||||||
|
|
||||||
|
This is why trying to do a `kill` command even with the `-9` (SIGKILL) option on a defunct (zombie) process doesn't work, because there is nothing to kill.
|
||||||
|
|
||||||
|
So, to kill a zombie process, as in to remove its name from the process list (the process table), you have to kill its parent. For instance, if PID 5878 is a zombie process, and its parent is PID 4809, then to kill the zombie (5878) you end the parent (4809):
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
`$ sudo kill -9 4809 #4809 is the parent, not the zombie`
|
||||||
|
```
|
||||||
|
|
||||||
|
My final word of warning about zombies. Be very careful when killing parent processes. If the parent of a process is PID 1 and you kill that, you'll reboot yourself!
|
||||||
|
|
||||||
|
And that will be an even scarier story to tell!
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: https://opensource.com/article/21/10/linux-zombie-process
|
||||||
|
|
||||||
|
作者:[Anderson Silva][a]
|
||||||
|
选题:[lujun9972][b]
|
||||||
|
译者:[译者ID](https://github.com/译者ID)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]: https://opensource.com/users/ansilva
|
||||||
|
[b]: https://github.com/lujun9972
|
||||||
|
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/ganapathy-kumar-unsplash.jpg?itok=5-DT99NA (Full moon on a hazy night)
|
||||||
|
[2]: https://opensource.com/article/21/8/linux-procps-ng
|
Loading…
Reference in New Issue
Block a user