Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/orhun/zps

A small utility for listing and reaping zombie processes on GNU/Linux.
https://github.com/orhun/zps

gnu-linux linux linux-utility process-management unix zombie-processes

Last synced: 4 days ago
JSON representation

A small utility for listing and reaping zombie processes on GNU/Linux.

Awesome Lists containing this project

README

        

![Logo](https://user-images.githubusercontent.com/24392180/66733887-b52b4780-ee69-11e9-86ee-ab04caf98287.png)

# zps [![Release](https://img.shields.io/github/release/orhun/zps.svg?color=590000&style=flat-square)](https://github.com/orhun/zps/releases)

### A small utility for listing and reaping zombie processes on GNU/Linux.

![zps](assets/demo-top.gif)

[![Build](https://img.shields.io/github/actions/workflow/status/orhun/zps/ci.yml?color=black&style=flat-square)](https://github.com/orhun/zps/actions?query=workflow%3A%22Continuous+Integration%22)
[![Docker Build](https://img.shields.io/github/actions/workflow/status/orhun/zps/docker.yml?color=black&style=flat-square&label=docker)](https://github.com/orhun/zps/actions?query=workflow%3A%22Docker+Automated+Builds%22)
[![Codacy](https://img.shields.io/codacy/grade/3d40a551806b4c788befba6d2920675b.svg?color=black&style=flat-square)](https://www.codacy.com/manual/orhun/zps?utm_source=github.com&utm_medium=referral&utm_content=orhun/zps&utm_campaign=Badge_Grade)
[![Codecov](https://img.shields.io/codecov/c/github/orhun/zps?color=black&style=flat-square)](https://codecov.io/gh/orhun/zps)
[![Stars](https://img.shields.io/github/stars/orhun/zps.svg?color=590000&style=flat-square)](https://github.com/orhun/zps/stargazers) [![License](https://img.shields.io/github/license/orhun/zps.svg?color=590000&style=flat-square)](./LICENSE)

On Unix and Unix-like computer operating systems, a [zombie process](https://en.wikipedia.org/wiki/Zombie_process) or defunct process is a process that has completed execution (via the [exit]() system call) but still has an entry in the process table. This occurs for child processes, where the entry is still needed to allow the parent process to read its child's exit status: once the exit status is read via the [wait]() system call, the zombie's entry is removed from the process table and it is said to be "reaped".

Unlike the normal processes, zombie processes cannot be removed from a system with the [kill]() command since they are already dead. (This is where the term's metaphor [zombie - an undead person] comes from.) To reap a zombie process, `SIGCHLD` signal can be sent to the parent process manually using the [kill]() command. If the parent process refuses to reap the zombie, then terminating the parent process (mostly with `SIGTERM` signal) can be an option. When a child process loses its parent, [init](https://en.wikipedia.org/wiki/Init) process becomes its new parent and it will reap any zombies since it executes the [wait]() system call periodically.

Zombie processes are not harmful since they are not affecting other processes or using any system resources. However, they do retain their [process ID](https://en.wikipedia.org/wiki/Process_identifier). This can lead to preventing new processes to launch if all the available PIDs were assigned to zombie processes. Considering Unix-like systems have a finite number of process IDs (`/proc/sys/kernel/pid_max`), it's one of the problems that zombie processes can cause. Another danger of zombie processes is that they can cause [resource leak](https://en.wikipedia.org/wiki/Resource_leak) if they stay as a zombie in the process table for a long time. Apart from these issues, having a few zombie processes won't be a big deal for the system although they might indicate a bug with their parent process.

[zproc.c](https://github.com/orhun/zps/blob/master/example/zproc.c) file can be compiled and run to see how zombie processes are created.

```
cd example/ && gcc -O3 -Wall zproc.c -o zproc && ./zproc
```

**zps** aims to list the running processes at a particular time with stats and indicate the zombie processes on this list. It can also reap these zombie processes automatically based on the arguments provided (by default using `SIGTERM`). See [usage](https://github.com/orhun/zps#usage) for more information.
Technically, **zps** reads process stats from [/proc](https://www.tldp.org/LDP/Linux-Filesystem-Hierarchy/html/proc.html) filesystem and uses [C POSIX library](https://en.wikipedia.org/wiki/C_POSIX_library) to handle listing, sending signals and other operations.

Table of Contents

- [Installation](#installation)
- [Arch Linux](#arch-linux)
- [Alpine Linux](#alpine-linux)
- [Fedora Linux](#fedora-linux)
- [CMake](#cmake)
- [Make](#make)
- [GCC](#gcc)
- [Docker](#docker)
- [Building an image](#building-an-image)
- [Running the image in container](#running-the-image-in-container)
- [Usage](#usage)
- [zps -r](#zps--r--reap)
- [zps -s](#zps--s--signal)
- [zps -p](#zps--p--prompt)
- [zps -q](#zps--q--quiet)
- [zps -n](#zps--n--no-color)
- [TODO(s)](#todos)
- [License](#license)
- [Copyright](#copyright)

## Installation

### Arch Linux

```
pacman -S zps
```

### Alpine Linux

```
apk add zps
```

### Fedora Linux

```
dnf install zps
```

### CMake

```
mkdir -p build && cd build
cmake ../ -DCMAKE_INSTALL_PREFIX=/usr
make
sudo make install
sudo ldconfig
```

### Make

```
make
sudo make install
```

### GCC

With manual compilation, you might want to also pass
`-DNDEBUG` to disable runtime assertions.

```
cd src/ && gcc -s -O3 -Wall -Wextra -pedantic zps.c -o zps
```

### Docker

#### Building an image

```
docker build -f docker/Dockerfile -t zps .
```

#### Running the image in container

```
docker run zps
```

## Usage

```
Usage:
zps [options]

Options:
-v, --version show version
-h, --help show help
-a, --all list all user-space processes
-r, --reap reap zombie processes
-s, --signal signal to be used on zombie parents
-p, --prompt show prompt for selecting processes
-q, --quiet reap in quiet mode
-n, --no-color disable color output
```

### zps -r/--reap

![zps -r](assets/demo-reap.gif)

### zps -s/--signal

![zps -s](assets/demo-signal.gif)

### zps -p/--prompt

![zps -p](assets/demo-prompt.gif)

### zps -q/--quiet

![zps -q](assets/demo-quiet.gif)

### zps -n/--no-color

![zps -n](assets/demo-no-color.gif)

## License

GNU General Public License v3.0 only ([GPL-3.0-only](https://www.gnu.org/licenses/gpl.txt))

## Copyright

Copyright © 2019-2024, [Orhun Parmaksız](mailto:[email protected])