Поиск по сайту:

Мониторинг производительности Linux с помощью команд Vmstat и Iostat


Это наша постоянная серия команд Linux и мониторинга производительности Linux. В этой статье вы узнаете о командах Vmstat и Iostat, которые доступны во всех основных Unix. -подобные (Linux/Unix/FreeBSD/Solaris) операционные системы.

Команда vmstat (также известная как инструмент статистики виртуальной памяти) показывает информацию о процессах, памяти, диске и активности ЦП в Linux, тогда как команда iostat используется для мониторинга загрузки ЦП. , статистика ввода-вывода системы для всех дисков и разделов.

Если команды vmstat и iostat недоступны на вашем компьютере с Linux, установите пакет sysstat. Команды vmstat, sar и iostat представляют собой набор пакетов, включенных в sysstat – инструменты мониторинга системы.

Вы можете загрузить и установить sysstat, используя архив с исходным кодом по ссылке sysstat, но мы рекомендуем устанавливать через менеджер пакетов.

Установите Sysstat в Linux

sudo apt install sysstat         [On Debian, Ubuntu and Mint]
sudo yum install sysstat         [On RHEL/CentOS/Fedora and Rocky Linux/AlmaLinux]
sudo emerge -a app-admin/sysstat [On Gentoo Linux]
sudo pacman -S sysstat           [On Arch Linux]
sudo zypper install sysstat      [On OpenSUSE]    

Изучите примеры команд Vmstat в Linux

В этом разделе вы узнаете о 6 примерах команд vmstat и их использовании со скриншотами.

1. Список активной и неактивной памяти.

В приведенном ниже примере имеется шесть столбцов. Значение столбцов подробно объяснено на странице руководства vmstat. Наиболее важными полями являются свободно в разделе «Память» и si, поэтому в столбце подкачки.

[root@tecmint ~]# vmstat -a

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free  inact active   si   so    bi    bo   in   cs us sy id wa st
 1  0      0 810420  97380  70628    0    0   115     4   89   79  1  6 90  3  0
  • Свободно – количество свободной/незанятой памяти.
  • si — данные перегружаются с диска каждую секунду в килобайтах.
  • so – каждую секунду выгружается на диск в килобайтах.

Примечание. Если вы запустите vmstat без параметров, он отобразит сводный отчет с момента загрузки системы.

2. Выполните vmstat «X» секунд и («Количество раз»)

С помощью этой команды vmstat выполняется каждые две секунды и автоматически останавливается после шести интервалов выполнения.

[root@tecmint ~]# vmstat 2 6

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0      0 810420  22064 101368    0    0    56     3   50   57  0  3 95  2  0
 0  0      0 810412  22064 101368    0    0     0     0   16   35  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   14   35  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   17   38  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   17   35  0  0 100  0  0
 0  0      0 810412  22064 101368    0    0     0     0   18   36  0  1 100  0  0

3. Vmstat с временными метками

Команда vmstat с параметром -t отображает временные метки для каждой напечатанной строки, как показано ниже.

[tecmint@tecmint ~]$ vmstat -t 1 5

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------ ---timestamp---
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0      0 632028  24992 192244    0    0    70     5   55   78  1  3 95  1  0        2012-09-02 14:57:18 IST
 1  0      0 632028  24992 192244    0    0     0     0  171  514  1  5 94  0  0        2012-09-02 14:57:19 IST
 1  0      0 631904  24992 192244    0    0     0     0  195  600  0  5 95  0  0        2012-09-02 14:57:20 IST
 0  0      0 631780  24992 192244    0    0     0     0  156  524  0  5 95  0  0        2012-09-02 14:57:21 IST
 1  0      0 631656  24992 192244    0    0     0     0  189  592  0  5 95  0  0        2012-09-02 14:57:22 IST

4. Статистика различных счетчиков

Команда vmstat с переключателем -s отображает сводку различных счетчиков событий и статистику памяти.

[tecmint@tecmint ~]$ vmstat -s

      1030800  total memory
       524656  used memory
       277784  active memory
       185920  inactive memory
       506144  free memory
        26864  buffer memory
       310104  swap cache
      2064376  total swap
            0  used swap
      2064376  free swap
         4539 non-nice user cpu ticks
            0 nice user cpu ticks
        11569 system cpu ticks
       329608 idle cpu ticks
         5012 IO-wait cpu ticks
           79 IRQ cpu ticks
           74 softirq cpu ticks
            0 stolen cpu ticks
       336038 pages paged in
        67945 pages paged out
            0 pages swapped in
            0 pages swapped out
       258526 interrupts
       392439 CPU context switches
   1346574857 boot time
         2309 forks

5. Мониторинг статистики дисков Linux

vmstat с опцией -d отображает статистику всех дисков Linux.

[tecmint@tecmint ~]$ vmstat -d

disk- ------------reads------------ ------------writes----------- -----IO------
       total merged sectors      ms  total merged sectors      ms    cur    sec
ram0       0      0       0       0      0      0       0       0      0      0
ram1       0      0       0       0      0      0       0       0      0      0
ram2       0      0       0       0      0      0       0       0      0      0
ram3       0      0       0       0      0      0       0       0      0      0
ram4       0      0       0       0      0      0       0       0      0      0
ram5       0      0       0       0      0      0       0       0      0      0
ram6       0      0       0       0      0      0       0       0      0      0
ram7       0      0       0       0      0      0       0       0      0      0
ram8       0      0       0       0      0      0       0       0      0      0
ram9       0      0       0       0      0      0       0       0      0      0
ram10      0      0       0       0      0      0       0       0      0      0
ram11      0      0       0       0      0      0       0       0      0      0
ram12      0      0       0       0      0      0       0       0      0      0
ram13      0      0       0       0      0      0       0       0      0      0
ram14      0      0       0       0      0      0       0       0      0      0
ram15      0      0       0       0      0      0       0       0      0      0
loop0      0      0       0       0      0      0       0       0      0      0
loop1      0      0       0       0      0      0       0       0      0      0
loop2      0      0       0       0      0      0       0       0      0      0
loop3      0      0       0       0      0      0       0       0      0      0
loop4      0      0       0       0      0      0       0       0      0      0
loop5      0      0       0       0      0      0       0       0      0      0
loop6      0      0       0       0      0      0       0       0      0      0
loop7      0      0       0       0      0      0       0       0      0      0
sr0        0      0       0       0      0      0       0       0      0      0
sda     7712   5145  668732  409619   3282  28884  257402  644566      0    126
dm-0   11578      0  659242 1113017  32163      0  257384 8460026      0    126
dm-1     324      0    2592    3845      0      0       0       0      0      2

6. Отображать статистику в мегабайтах

vmstat по умолчанию отображает статистику памяти в килобайтах, но вы также можете отображать отчеты с размерами памяти в мегабайтах с помощью аргумента -S M. Рассмотрим следующий пример.

[root@tecmint ~]# vmstat -S M 1 5

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0      0    346     53    476    0    0    95     8   42   55  0  2 96  2  0
 0  0      0    346     53    476    0    0     0     0   12   15  0  0 100  0  0
 0  0      0    346     53    476    0    0     0     0   32   62  0  0 100  0  0
 0  0      0    346     53    476    0    0     0     0   15   13  0  0 100  0  0
 0  0      0    346     53    476    0    0     0     0   34   61  0  1 99  0  0

Изучите примеры команд Iostat в Linux

В этом разделе вы узнаете о 6 примерах команд iostat и их использовании со скриншотами.

7. Отображение статистики процессора и ввода-вывода дисков.

iostat без аргументов отображает статистику CPU и I/O для всех разделов, как показано ниже.

[root@tecmint ~]# iostat

Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.12    0.01    1.54    2.08    0.00   96.24

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.59       161.02        13.48    1086002      90882
dm-0              5.76       159.71        13.47    1077154      90864
dm-1              0.05         0.38         0.00       2576          0

8. Показывает статистику процессора Linux.

iostat с аргументами -c отображает только статистику ЦП, как показано ниже.

[root@tecmint ~]# iostat -c

Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.12    0.01    1.47    1.98    0.00   96.42

9. Показывает статистику ввода-вывода дисков Linux.

iostat с аргументами -d отображает только дисковую статистику I/O для всех разделов, как показано.

[root@tecmint ~]# iostat -d

Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.35       149.81        12.66    1086002      91746
dm-0              5.37       148.59        12.65    1077154      91728
dm-1              0.04         0.36         0.00       2576          0

10. Показывает статистику ввода-вывода конкретного устройства.

По умолчанию он отображает статистику всех разделов, а аргументы -p и имени устройства отображают только статистику дисков I/O только для конкретного устройства, как показано.

[root@tecmint ~]# iostat -p sda

Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.11    0.01    1.44    1.92    0.00   96.52

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.32       148.52        12.55    1086002      91770
sda1              0.07         0.56         0.00       4120         18
sda2              3.22       147.79        12.55    1080650      91752

11. Отображение статистики LVM

С параметром -N (прописные буквы) отображается только статистика LVM, как показано.

[root@tecmint ~]# iostat -N

Linux 2.6.32-279.el6.i686 (linux-console.net)         09/03/2012      _i686_  (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.11    0.01    1.39    1.85    0.00   96.64

Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               3.20       142.84        12.16    1086002      92466
vg_tecmint-lv_root     5.13       141.68        12.16    1077154      92448
vg_tecmint-lv_swap     0.04         0.34         0.00       2576          0

12. Проверьте версию Iostat

С помощью параметра -V (прописные буквы) отображается версия iostat, как показано.

[root@tecmint ~]# iostat -V

sysstat version 11.7.3
(C) Sebastien Godard (sysstat  orange.fr)

vmstat и iostat содержат ряд столбцов и флагов, которые невозможно объяснить подробно. Если вы хотите узнать больше об этом, вы можете обратиться к справочной странице vmstat и iostat.

man vmstat
man iostat

Пожалуйста, поделитесь ею, если вы считаете эту статью полезной, через поле для комментариев ниже.