vmstat命令

1.安装

vmstat是在sysstat包里的,安装时执行命令yum install -y sysstat即可。

2.参数说明

vmstat常见命令格式如下:

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;
-V:显示vmstat版本信息;

3.使用

一般vmstat工具的使用是通过两个数字参数来完成的,
第一个参数是采样的时间间隔,单位是秒,
第二个参数是采样的次数,

如下所示,表示每隔1秒采样,共采样5次

# vmstat 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
 2  0  60160 610692      0 293948    0    1  1160   399   16  181  2  1 96  0  0
 0  0  60160 610544      0 293948    0    0     0     0   78  114  0  0 100  0  0
 0  0  60160 610544      0 293948    0    0     0     0   69  106  0  1 99  0  0
 0  0  60160 610544      0 293948    0    0     0     0   61   94  0  0 100  0  0
 0  0  60160 610544      0 293948    0    0     0     0   68  103  0  0 100  0  0

vmstat命令执行结果共分为6部分:procs、memory、swap、io、system、cpu。

输出内容的含义如下:

procs   #进程
r(run):表示运行或等待CPU时间片的进程数,如果该值长期大于服务器CPU的个数,则说明CPU资源不足。一般负载超过了3就比较高,超过了5就高,超过了10就不正常了,服务器的状态很危险;
b(block):表示等待资源的进程数,这个资源指的是I/O、内存等。比如,当磁盘读写非常频繁时,写数据就会变得很慢,此时CPU运算很快就结束了,但进程需要把计算的结果写入磁盘,这样进程的任务才算完成,此时这个进程只能慢慢地等待磁盘了,这个进程就是这个b状态。该数值如果长时间大于1,则需要去查找问题;

memory  #内存,单位:KB
swap:虚拟内存(swap空间)已使用的大小;
free:空闲的物理内存的大小;
buff:存放目录里面有什么内容,文件的属性以及权限等;
cache:用来记忆我们打开过的文件和程序,做文件缓冲(当程序使用内存时,buff/cache很快就会被使用);

swap    #swap空间,单位:KB,内存够用时,si和so值都为0,如果这两个值长期大于0,表示内存不够用了,系统性能会受到影响
si:表示从swap空间写入内存的数据量;
so:表示从内存写入swap空间的数据库;


io      #单位:块/秒
bi:每秒读取的块数(读磁盘),现在的Linux版本块的大小为1024bytes;
bo:每秒写入的块数(写磁盘);

system  #系统,这2个值越大,会看到由内核消耗的CPU时间会越大
in:每秒CPU的中断次数,包括时间中断;
cs:每秒上下文切换数,例如我们调用系统函数,就要进行上下文切换,线程的切换,也要进行上下文切换,这个值越小越好;

cpu     #以百分比显示
us(user time):用户进程执行时间;
sy(system time):系统进程执行时间;
id:空闲时间(包括IO等待时间);
wa:等待IO时间,wa的值高时,说明IO等待比较严重,这可能由于磁盘大量做随机访问造成的,也有可能是磁盘出现瓶颈;
st:表示被偷走的CPU所占百分比(一般都为0,不用关注);

us + sy + id + wa =100%     #这个是只是近似值

你可能感兴趣的:(Linux)