Наши партнеры

UnixForum





Библиотека сайта rus-linux.net

Как ограничить загрузку процессора в Ubuntu Linux с помощью CPULimit

Оригинал: How to limit CPU usage with CPULimit on Ubuntu Linux
Автор: howtoforge
Дата публикации: 14 августа 2018 года
Перевод: А. Кривошей
Дата перевода: февраль 2019 г.

В этом руководстве описывается, как ограничить загрузку процессора в Ubuntu. Я буду использовать для этой цели утилиту cpulimit. Cpulimit - это утилита, которая ограничивает загрузку ЦП конкретным процессом (задается в процентах, а не во времени ЦП). Это особенно полезно при выполнении пакетных заданий, когда вы не хотите, чтобы они забирали слишком много циклов ЦП. Целью cpulimit является ограничение использования процессора конкретным процессом. Она не изменяет значение nice или другие параметры приоритета планирования, а упраляет реальным использованием процессора. Кроме того, она может динамически и быстро адаптироваться к общей загрузке системы.

Контроль используемого количества циклов ЦП осуществляется путем отправки сигналов SIGSTOP и SIGCONT POSIX процессам. Все дочерние процессы и потоки указанного процесса будут использовать один и тот же процент загрузки ЦП.

1. Одно предварительное примечание

Это руководство основано на использовании серверной версии Ubuntu 18.04 LTS (Bionic Beaver), поэтому вам следует настроить базовую установку сервера Ubuntu 18.04, прежде чем продолжить работу. Система должна иметь статический IP-адрес. Я использую 192.168.1.100 в качестве своего IP-адреса в этом руководстве, а server1.example.com в качестве имени хоста.

2. Установка CPULimit

Для начала нам нужно установить cpulimit следующим образом:

$ apt-get update
$ apt-get install cpulimit

3. Ограничение загрузки CPU

Теперь мы проверим утилиту для ограничения использования процессора. Для этого мы сначала проверим использование ЦП без cpulimit, а затем запустим cpulimit, чтобы оценить ее работу. Давайте проясним это на примере.

Вот пример того, как можно загрузить приложением одноядерный процессор:

$ dd if=/dev/zero of=/dev/null &

пример того, как можно загрузить приложением одноядерный процессор

Затем мы проверим загрузку процессора командой:

$ top

top - 11:24:18 up 49 min,  1 user,  load average: 0.94, 1.02, 1.79
Tasks: 249 total,   2 running, 247 sleeping,   0 stopped,   0 zombie
%Cpu(s): 13.4 us, 11.6 sy,  0.0 ni, 74.9 id,  0.0 wa,  0.1 hi,  0.0 si,  0.0 st
KiB Mem:   1010540 total,   271652 used,   738888 free,    21760 buffers
KiB Swap:  1048572 total,        0 used,  1048572 free.   158204 cached Mem

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                   
 1850 root      20   0    7224    616    520 R 100.0  0.1   1:20.33 dd                        
 1851 root      20   0   24952   1756   1180 R   0.3  0.2   0:00.03 top                       
    1 root      20   0   33480   2776   1456 S   0.0  0.3   0:05.31 init                      
    2 root      20   0       0      0      0 S   0.0  0.0   0:00.01 kthreadd        

Как мы видим, загрузка ЦП достигла 100%, теперь мы задействуем cpulimit для ограничения использования ЦП. Мы можем вывести этот процесс на передний план, используя команду fg, и закрыть его, нажав CTRL+C.

$ fg

вывод процесса на передний план

Теперь мы можем протестировать cpulimit, чтобы увидеть, действительно ли она делает то, что должна. Давайте проверим это следующим образом:

$ cpulimit -l 30 dd if=/dev/zero of=/dev/null &

root@server1:~# cpulimit -l 30 dd if=/dev/zero of=/dev/null &
[1] 1852
root@server1:~# Process 1853 detected

[1]+  Done                    cpulimit -l 30 dd if=/dev/zero of=/dev/null
root@server1:~#

Теперь мы проверим загрузку процессора командой top:

$ top
top - 11:30:54 up 55 min,  1 user,  load average: 0.20, 0.58, 1.34
Tasks: 250 total,   2 running, 247 sleeping,   1 stopped,   0 zombie
%Cpu(s):  4.5 us,  4.1 sy,  0.0 ni, 91.4 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem:   1010540 total,   271944 used,   738596 free,    21816 buffers
KiB Swap:  1048572 total,        0 used,  1048572 free.   158212 cached Mem

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                   
 1853 root      20   0    7224    612    520 T  33.8  0.1   0:35.53 dd                        
    1 root      20   0   33480   2776   1456 S   0.0  0.3   0:05.37 init                      
    2 root      20   0       0      0      0 S   0.0  0.0   0:00.01 kthreadd                  
    3 root      20   0       0      0      0 S   0.0  0.0   0:00.02 ksoftirqd/0               
    4 root      20   0       0      0      0 S   0.0  0.0   0:00.00 kworker/0:0

Теперь вы можете видеть, что загрузка процессора снизилась со 100% до 33,8%. Итак, мы успешно проверили в действии утилиту cpulimit, которая может ограничивать использование одноядерного процессора.

Вот пример того, как загрузить приложением многоядерный процессор:

Для проверки количества вашего ядра процессора используйте команду:

$ nproc

В моем случае это было 4.
Теперь мы продолжим проверять загрузку процессора для приложения без cpulimit во всех 4 ядрах следующим образом:

$ for j in `seq 1 4`; do dd if=/dev/zero of=/dev/null & done

Эта строка запустит команду, используя все ядра, и выдаст вывод в виде:

root@server1:~# for j in `seq 1 4`; do dd if=/dev/zero of=/dev/null & done
[1] 1263
[2] 1264
[3] 1265
[4] 1266
root@server1:~#

Теперь проверьте использование процессора с помощью команды top:

$ top
top - 11:47:45 up 4 min,  1 user,  load average: 3.63, 1.53, 0.57
Tasks: 290 total,   5 running, 285 sleeping,   0 stopped,   0 zombie
%Cpu0  : 48.3 us, 51.3 sy,  0.0 ni,  0.0 id,  0.0 wa,  0.3 hi,  0.0 si,  0.0 st
%Cpu1  : 47.8 us, 52.2 sy,  0.0 ni,  0.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
%Cpu2  : 53.3 us, 46.4 sy,  0.0 ni,  0.0 id,  0.0 wa,  0.3 hi,  0.0 si,  0.0 st
%Cpu3  : 52.0 us, 48.0 sy,  0.0 ni,  0.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem:   1010540 total,   209712 used,   800828 free,    20276 buffers
KiB Swap:  1048572 total,        0 used,  1048572 free.    93632 cached Mem

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                   
 1263 root      20   0    7224    612    520 R 100.0  0.1   2:21.40 dd                        
 1264 root      20   0    7224    616    520 R 100.0  0.1   2:21.41 dd                        
 1265 root      20   0    7224    612    520 R  99.0  0.1   2:21.03 dd                        
 1266 root      20   0    7224    616    520 R  98.0  0.1   2:20.82 dd                        
 1281 root      20   0  104416   3992   2920 S   1.0  0.4   0:00.03 sshd                      
 1283 root      20   0  104416   3988   2920 S   1.0  0.4   0:00.03 sshd                      
 1279 root      20   0  104556   4008   2924 S   0.7  0.4   0:00.08 sshd    

Команда dd потребляет почти 100% всех ядер CPU. Далее мы проверим эту команду с помощью утилиты cpulimit. Для этого убейте предыдущие следы команды dd следующим образом:

$ killall dd
root@server1:~# killall dd
[1]   Terminated              dd if=/dev/zero of=/dev/null
[3]-  Terminated              dd if=/dev/zero of=/dev/null
[2]-  Terminated              dd if=/dev/zero of=/dev/null
[4]+  Terminated              dd if=/dev/zero of=/dev/null
root@server1:~#

Теперь используйте cpulimit с той же командой, как показано ниже:

$ for j in `seq 1 4`; do cpulimit -l 20 dd if=/dev/zero of=/dev/null & done
root@server1:~# for j in `seq 1 4`; do cpulimit -l 20 dd if=/dev/zero of=/dev/null & done
[1] 1429
[2] 1430
[3] 1431
[4] 1432
root@server1:~# Process 1434 detected
Process 1433 detected
Process 1437 detected
Process 1439 detected

[1]   Done                    cpulimit -l 20 dd if=/dev/zero of=/dev/null
[2]   Done                    cpulimit -l 20 dd if=/dev/zero of=/dev/null
[3]-  Done                    cpulimit -l 20 dd if=/dev/zero of=/dev/null
[4]+  Done                    cpulimit -l 20 dd if=/dev/zero of=/dev/null
root@server1:~#

Теперь проверьте использование процессора с помощью утилиты top.

$ top
top - 11:59:10 up 16 min,  2 users,  load average: 0.47, 0.71, 0.81
Tasks: 256 total,   2 running, 251 sleeping,   3 stopped,   0 zombie
%Cpu0  :  2.0 us,  2.0 sy,  0.0 ni, 96.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
%Cpu1  : 26.2 us, 22.8 sy,  0.0 ni, 50.7 id,  0.0 wa,  0.3 hi,  0.0 si,  0.0 st
%Cpu2  : 14.0 us, 12.3 sy,  0.0 ni, 73.8 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
%Cpu3  : 13.3 us, 11.6 sy,  0.0 ni, 75.1 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem:   1010540 total,   204064 used,   806476 free,    20408 buffers
KiB Swap:  1048572 total,        0 used,  1048572 free.    98340 cached Mem

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                   
 1433 root      20   0    7224    612    520 T  28.2  0.1   0:12.00 dd                        
 1439 root      20   0    7224    616    520 R  26.6  0.1   0:12.13 dd                        
 1434 root      20   0    7224    612    520 T  25.3  0.1   0:11.97 dd                        
 1437 root      20   0    7224    612    516 T  22.9  0.1   0:11.93 dd                        
    7 root      20   0       0      0      0 S   0.3  0.0   0:00.22 rcu_sched                 
    8 root      20   0       0      0      0 S   0.3  0.0   0:00.21 rcuos/0      

Как вы можете видеть выше, использование CPU ограничено со 100% до почти 20% для многоядерного процессора.
Поздравляем! Мы успешно протестировали cpulimit для ограничения использования процессора в Ubuntu 18.04.

4. Ссылки:

Ubuntu: http://www.ubuntu.com/

cpulimit: https://github.com/opsengine/cpulimit