Linux 监控命令之 vmstat

安装

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

参数说明

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版本信息;

使用

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

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

Linux 监控命令之 vmstat_第1张图片

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)