vmstat命令: 用来获得有关进程、虚存、页面交换空间及 CPU活动的信息。这些信息反映了系统的负载情况
用法
vmstat [-a] [-n] [-S unit] [delay [ count]]
vmstat [-s] [-n] [-S unit]
vmstat [-m] [-n] [delay [ count]]
vmstat [-d] [-n] [delay [ count]]
vmstat [-p disk partition] [-n] [delay [ count]]
vmstat [-f]
vmstat [-V]
-a:显示活跃和非活跃内存
-f:显示从系统启动至今的fork数量 。
-m:显示slabinfo
-n:只在开始时显示一次各字段名称。
-s:显示内存相关统计信息及多种系统活动数量。
delay:刷新时间间隔。如果不指定,只显示一条结果。
count:刷新次数。如果不指定刷新次数,但指定了刷新时间间隔,这时刷新次数为无穷。
-d:显示磁盘相关统计信息。
-p:显示指定磁盘分区统计信息
-S:使用指定单位显示。参数有 k 、K 、m 、M ,分别代表1000、1024、1000000、1048576字节(byte)。默认单位为K(1024 bytes)
-V:显示vmstat版本信息
Procs(进程)
r
等待执行的任务数
展示了正在执行和等待cpu资源的任务个数。当这个值超过了cpu个数,就会出现cpu瓶颈。
B
等待IO的进程数量
Memory(内存)
swpd
正在使用虚拟的内存大小,单位k
free
空闲内存大小
buff
已用的buff大小,对块设备的读写进行缓冲
cache
已用的cache大小,文件系统的cache
inact
非活跃内存大小,即被标明可回收的内存,区别于free和active
具体含义见:概念补充(当使用-a选项时显示)
active
活跃的内存大小
具体含义见:概念补充(当使用-a选项时显示)
Swap
si
每秒从交换区写入内存的大小(单位:kb/s)
so
每秒从内存写到交换区的大小
IO
bi
每秒读取的块数(读磁盘)
bo
每秒写入的块数(写磁盘)
system
in
每秒中断数,包括时钟中断
这两个值越大,会看到由内核消耗的cpu时间会越多
cs
每秒上下文切换数
CPU(以百分比表示)
Us
用户进程执行消耗cpu时间(user time)
us的值比较高时,说明用户进程消耗的cpu时间多,但是如果长期超过50%的使用,那么我们就该考虑优化程序算法或其他措施了
Sy
系统进程消耗cpu时间(system time)
sys的值过高时,说明系统内核消耗的cpu资源多,这个不是良性的表现,我们应该检查原因。
Id
空闲时间(包括IO等待时间)
wa
等待IO时间
Wa过高时,说明io等待比较严重,这可能是由于磁盘大量随机访问造成的,也有可能是磁盘的带宽出现瓶颈。
常见问题处理
如果r经常大于4,且id经常少于40,表示cpu的负荷很重。
如果pi,po长期不等于0,表示内存不足。
如果disk经常不等于0,且在b中的队列大于3,表示io性能不好。
1.)如果在processes中运行的序列(process r)是连续的大于在系统中的CPU的个数表示系统现在运行比较慢,有多数的进程等待CPU。
2.)如果r的输出数大于系统中可用CPU个数的4倍的话,则系统面临着CPU短缺的问题,或者是CPU的速率过低,系统中有多数的进程在等待CPU,造成系统中进程运行过慢。
3.)如果空闲时间(cpu id)持续为0并且系统时间(cpu sy)是用户时间的两倍(cpu us)系统则面临着CPU资源的短缺。
版权声明:本文为博主原创文章,未经博主允许不得转载。
vmstat详解命令