.gitignore | ||
default_values_backup.conf | ||
install.sh | ||
LICENSE | ||
nohang | ||
nohang.1 | ||
nohang.conf | ||
nohang.service | ||
purge.sh | ||
README.md |
Nohang
Nohang is a highly configurable daemon for Linux which is able to correctly prevent out of memory (OOM) conditions and save disk cache.
What is the problem?
OOM killer doesn't prevent OOM conditions. And OOM conditions may cause freezes, livelocks, drop caches and killing (via SIGKILL) multiple processes instead of terminating (via SIGTERM) one process.
Here are the statements of some users:
"How do I prevent Linux from freezing when out of memory? Today I (accidentally) ran some program on my Linux box that quickly used a lot of memory. My system froze, became unresponsive and thus I was unable to kill the offender. How can I prevent this in the future? Can't it at least keep a responsive core or something running?"
"With or without swap it still freezes before the OOM killer gets run automatically. This is really a kernel bug that should be fixed (i.e. run OOM killer earlier, before dropping all disk cache). Unfortunately kernel developers and a lot of other folk fail to see the problem. Common suggestions such as disable/enable swap, buy more RAM, run less processes, set limits etc. do not address the underlying problem that the kernel's low memory handling sucks camel's balls."
Also look at Why are low memory conditions handled so badly? (discussion with 480+ posts on r/linux).
Solution
- Use of earlyoom. This is a simple and lightweight OOM preventer written in C.
- Use of oomd. This is a userspace OOM killer for linux systems whitten in C++ and developed by Facebook.
- Use of nohang.
Some features
SIGKILL
andSIGTERM
as signals that can be sent to the victim- impact on the badness of processes via matching their names with regular expressions
- possibility of restarting processes via command like
systemctl restart something
if the process is selected as a victim - GUI notifications: results of preventings OOM and low memory warnings
zram
support (mem_used_total
as a trigger)- customizable intensity of monitoring
- convenient configuration with a well commented config file (there are 35 parameters in the config)
- look at the config to find more
Demo
Video: nohang prevents OOM after the command while true; do tail /dev/zero; done
has been executed.
Requirements
Linux 3.14+
andPython 3.4+
for basic uselibnotify
(Fedora, Arch) orlibnotify-bin
(Debian, Ubuntu) to show GUI notifications
Memory and CPU usage
- VmRSS is 10 — 14 MiB depending on the settings
- CPU usage depends on the level of available memory (the frequency of memory status checks increases as the amount of available memory decreases) and monitoring intensity (can be changed by user via config)
Status
The program is unstable and some fixes are required before the first stable version will be released (need documentation, translation, review and some optimisation).
Download
$ git clone https://github.com/hakavlad/nohang.git
$ cd nohang
Installation and start for systemd users
$ sudo ./install.sh
Purge
$ sudo ./purge.sh
Command line options
./nohang -h
usage: nohang [-h] [-c CONFIG]
optional arguments:
-h, --help show this help message and exit
-c CONFIG, --config CONFIG
path to the config file, default values:
./nohang.conf, /etc/nohang/nohang.conf
How to configure nohang
The program can be configured by editing the config file. The configuration includes the following sections:
- Memory levels to respond to as an OOM threat
- The frequency of checking the level of available memory (and CPU usage)
- The prevention of killing innocent victims
- Impact on the badness of processes via matching their names with regular expressions
- The execution of a specific command instead of sending the SIGTERM signal
- GUI notifications:
- results of preventing OOM
- low memory warnings
- Preventing the slowing down of the program
- Output verbosity
Just read the description of the parameters and edit the values. Please restart nohang to apply changes. Default path to the config arter installing via ./install.sh
is /etc/nohang/nohang.conf
.
Feedback
Please create issues. Use cases, feature requests and any questions are welcome.