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.