Búsqueda de sitios web

Monitoreo del rendimiento de Linux con comandos Vmstat e Iostat


Esta es nuestra serie continua de comandos de Linux y monitoreo del rendimiento de Linux. En este artículo, aprenderá sobre los comandos Vmstat e Iostat, que están disponibles en los principales Unix. -como (Linux/Unix/FreeBSD/Solaris) Sistemas Operativos.

El comando vmstat (también conocido como herramienta de estadística de memoria virtual) muestra información sobre procesos, memoria, disco y actividad de la CPU en Linux, mientras que el comando iostat se usa para monitorear la utilización de la CPU. , estadísticas de entrada/salida del sistema para todos los discos y particiones.

Si los comandos vmstat y iostat no están disponibles en su máquina Linux, instale el paquete sysstat. Los comandos vmstat, sar y iostat son la colección de paquetes incluidos en sysstat, las herramientas de monitoreo del sistema.

Puede descargar e instalar sysstat utilizando el archivo tar de origen desde el enlace sysstat, pero recomendamos instalarlo a través del administrador de paquetes.

Instalar Sysstat en 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]    

Aprenda ejemplos de comandos Vmstat en Linux

En esta sección, aprenderá sobre 6 ejemplos de comandos vmstat y su uso con capturas de pantalla.

1. Listar la memoria activa e inactiva

En el siguiente ejemplo, hay seis columnas. El significado de las columnas se explica en detalle en la página de manual de vmstat. Los campos más importantes están libre en memoria y si en la columna de intercambio.

[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
  • Libre: cantidad de espacios de memoria libres/inactivos.
  • si: se intercambia cada segundo desde el disco en KiloBytes.
  • so: se cambia cada segundo al disco en KiloBytes.

Nota: Si ejecuta vmstat sin parámetros, mostrará un informe resumido desde el inicio del sistema.

2. Ejecute vmstat 'X' segundos y ('Número de veces)

Con este comando, vmstat se ejecuta cada dos segundos y se detiene automáticamente después de ejecutar seis intervalos.

[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 con marcas de tiempo

El comando vmstat con el parámetro -t muestra marcas de tiempo con cada línea impresa como se muestra a continuación.

[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. Estadísticas de varios contadores

El comando vmstat con el modificador -s muestra un resumen de varios contadores de eventos y estadísticas de memoria.

[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. Supervisar las estadísticas de los discos de Linux

vmstat con la opción -d muestra todas las estadísticas de discos de 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. Mostrar estadísticas en megabytes

vmstat muestra estadísticas de memoria en kilobytes de forma predeterminada, pero también puede mostrar informes con tamaños de memoria en megabytes con el argumento -S M. Considere el siguiente ejemplo.

[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

Aprenda ejemplos de comandos Iostat en Linux

En esta sección, aprenderá sobre 6 ejemplos de comandos iostat y su uso con capturas de pantalla.

7. Mostrar estadísticas de CPU y E/S de discos

iostat sin argumentos muestra estadísticas de CPU y E/S de todas las particiones como se muestra a continuación.

[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. Muestra estadísticas de CPU de Linux

iostat con argumentos -c muestra solo estadísticas de CPU como se muestra a continuación.

[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. Muestra estadísticas de E/S de discos de Linux

iostat con argumentos -d muestra solo estadísticas de E/S del disco de todas las particiones, como se muestra.

[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. Muestra estadísticas de E/S de un dispositivo específico

De forma predeterminada, muestra estadísticas de todas las particiones, con -p y los argumentos de nombre de dispositivo muestran solo estadísticas de E/S de discos para dispositivos específicos solo como se muestra.

[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. Mostrar estadísticas de LVM

Con el parámetro -N (mayúscula) se muestran solo estadísticas LVM como se muestra.

[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. Verifique la versión de Iostat

Con el parámetro -V (mayúscula) se muestra la versión de iostat como se muestra.

[root@tecmint ~]# iostat -V

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

vmstat y iostat contienen una serie de columnas y indicadores que tal vez no sea posible explicar en detalle. Si desea saber más al respecto, puede consultar la página de manual de vmstat y iostat.

man vmstat
man iostat

Compártalo si encuentra útil este artículo a través de nuestro cuadro de comentarios a continuación.