016-Vmstat命令

 015中说的是w命令,它查看的是当前服务器有没有压力,那如何知道细节呢(CPU,内存,磁盘)?缓存

[root@Carlton scripts]# grep -c 'processor' /proc/cpuinfo 
1
[root@Carlton scripts]# vmstat 
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 112320  24076 219532    0    0   125    10  109   38  1  0 98  2  0

 

上面讲的 w 查看的是系统总体上的负载,经过看那个数值能够知道当前系统有没有压力,可是具体是哪里(CPU, 内存,磁盘等)有压力就没法判断了。经过 vmstat 就能够知道具体是哪里有压力。vmstat命令打印的结果共分为6部分:procs, memory, swap, io, system, cpu. 请重点关注一下r b si so bi bo几列。服务器

1)procs 显示进程相关信息性能

r :表示运行和等待cpu时间片的进程数,若是长期大于服务器cpu的个数,则说明cpu不够用了;ui

b :表示等待资源的进程数,好比等待I/O, 内存等,这列的值若是长时间大于1,则须要关注一下了;code

2)memory 内存相关信息对象

swpd :表示切换到交换分区中的内存数量 ;进程

free :当前空闲的内存数量;ip

buff :缓冲大小,(即将写入磁盘的);内存

cache :缓存大小,(从磁盘中读取的);资源

3)swap 内存交换状况

si :由交换区写入到内存的数据量;

so :由内存写入到交换区的数据量;

4)io 磁盘使用状况

bi :从块设备读取数据的量(读磁盘);

bo: 从块设备写入数据的量(写磁盘);

5)system 显示采集间隔内发生的中断次数

in :表示在某一时间间隔中观测到的每秒设备中断数;

cs :表示每秒产生的上下文切换次数;

6)CPU 显示cpu的使用状态

us :显示了用户下所花费 cpu 时间的百分比;

sy :显示系统花费cpu时间百分比;

id :表示cpu处于空闲状态的时间百分比;

wa :表示I/O等待所占用cpu时间百分比;

st :表示被偷走的cpu所占百分比(通常都为0,不用关注);

以上所介绍的各个参数中,关注r列,b列,和wa列,三列表明的含义在上边说得已经很清楚。IO部分的bi以及bo也是要常常参考的对象。若是磁盘io压力很大时,这两列的数值会比较高。另外当si, so两列的数值比较高,而且在不断变化时,说明内存不够了,内存中的数据频繁交换到交换分区中,这每每对系统性能影响极大。