From 6bccc3402f8699d90a5b3153c16a8e142fb2074c Mon Sep 17 00:00:00 2001 From: Alexey Avramov Date: Wed, 20 Jun 2018 02:48:06 +0900 Subject: [PATCH] =?UTF-8?q?=D0=BF=D1=80=D0=B0=D0=B2=D0=BA=D0=B0=20=D0=BA?= =?UTF-8?q?=D0=BE=D0=BD=D1=84=D0=B8=D0=B3=D0=B0=20=D0=B8=20=D1=80=D0=B8?= =?UTF-8?q?=D0=B4=D0=BC=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 6 +++--- install.sh | 9 +++++---- nohang.conf | 4 ++-- 3 files changed, 10 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index bea4181..6ad4059 100644 --- a/README.md +++ b/README.md @@ -35,12 +35,12 @@ https://2ch.hk/s/res/2310304.html#2311483, https://archive.li/idixk ### Зачем нужен nohang, если уже есть earlyoom? -- `earlyoom` завершает (точнее убивает) процессы исключительно с помощью сигнала `SIGKILL`, в то время как `nohang` дает возможность сначала отправлять `SIGTERM`, и только если процесс не реагирует на `SIGTERM` - отправляется сигнал `SIGKILL`. -- `earlyoom` не поддерживает работу со `zram` и не реагирует на общую долю `zram` в памяти (`mem_used_total`). Это может привести к тому, что система все также встанет колом, как если бы `earlyoom` и не было (если `disksize` большой, а энтропия сжимаемых данных велика). `Nohang` позволяет избавиться от этой проблемы. По умолчанию если доля `zram` достигнет 60% памяти - будет отправлен сигнал `SIGTERM` процессу с наибольшим `oom_score`. +- `Earlyoom` завершает (точнее убивает) процессы исключительно с помощью сигнала `SIGKILL`, в то время как `nohang` дает возможность сначала отправлять `SIGTERM`, и только если процесс не реагирует на `SIGTERM` - отправляется сигнал `SIGKILL`. +- `Earlyoom` не поддерживает работу со `zram` и не реагирует на общую долю `zram` в памяти (`mem_used_total`). Это может привести к тому, что система все также встанет колом, как если бы `earlyoom` и не было (если `disksize` большой, а энтропия сжимаемых данных велика). `Nohang` позволяет избавиться от этой проблемы. По умолчанию если доля `zram` достигнет 60% памяти - будет отправлен сигнал `SIGTERM` процессу с наибольшим `oom_score`. ### Некоторые особенности - задача - препятствовать зависанию системы при нехватке доступной памяти, а также корректное завершение процессов с целью увеличения объема доступной памяти -- демон на Python 3, VmRSS от 10 до 14 MiB в зависимости от настроек +- демон на Python 3, VmRSS от 9.5 до 12.9 MiB в зависимости от настроек - требуется ядро `Linux 3.14` или новее - периодически проверяет объем доступной памяти, при дефиците памяти отправляет `SIGKILL` или `SIGTERM` процессу с наибольшим `oom_score` - поддержка работы со `zram`, возможность реакции на `mem_used_total` diff --git a/install.sh b/install.sh index 285dda7..146c0d0 100755 --- a/install.sh +++ b/install.sh @@ -1,20 +1,21 @@ #!/bin/bash -v -cp -f nohang /usr/local/bin/ +cp nohang /usr/local/bin/ chmod 755 /usr/local/bin/nohang mkdir /etc/nohang chmod 755 /etc/nohang -cp -f nohang.conf /etc/nohang/ +cp nohang.conf /etc/nohang/ chmod 644 /etc/nohang/nohang.conf gzip -k nohang.1 mkdir /usr/local/share/man/man1 chmod 755 /usr/local/share/man/man1 -cp -f nohang.1.gz /usr/local/share/man/man1/ +cp nohang.1.gz /usr/local/share/man/man1/ chmod 644 /usr/local/share/man/man1/nohang.1.gz +rm nohang.1.gz -cp -f nohang.service /etc/systemd/system/ +cp nohang.service /etc/systemd/system/ chmod 644 /etc/systemd/system/nohang.service systemctl daemon-reload systemctl enable nohang diff --git a/nohang.conf b/nohang.conf index 4802c8d..ee5c6e1 100644 --- a/nohang.conf +++ b/nohang.conf @@ -36,7 +36,7 @@ print_sleep_periods = True В Fedora 28 значение True вызывает увеличение потребления памяти процессом на 200 MiB, в Debian 8 и 9 такой проблемы нет. -mlockall = True +mlockall = False Установка отрицательных значений self_nice и self_oom_score_adj требует наличия root прав. @@ -140,7 +140,7 @@ decrease_oom_score_adj = True Допустимые значения - целые числа из диапазона [0; 1000] -oom_score_adj_max = 20 +oom_score_adj_max = 30 #####################################################################