vmstat命令用来显示Linux系统虚拟内存状态,也可以报告关于进程、内存、I/O等系统整体运行状态。
1、使用vmstat --help命令查看:
hejianping@ubuntu:~$ vmstat --help vmstat: invalid option -- '-' usage: vmstat [-V] [-n] [delay [count]] -V prints version. -n causes the headers not to be reprinted regularly. -a print inactive/active page stats. -d prints disk statistics -D prints disk table -p prints disk partition statistics -s prints vm table -m prints slabinfo -S unit size delay is the delay between updates in seconds. unit size k:1000 K:1024 m:1000000 M:1048576 (default is K) count is the number of updates.
-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版本信息。
2、实例 vmstat 10 10(在10秒内进行10次采样),主要看r参数列,排查CPU处理进程是否堵塞:
hejianping@ubuntu:~$ vmstat 10 10
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
r b swpd free buff cache si so bi bo in cs us sy id wa
5 0 162136 13602808 906324 20947420 0 0 2 169 0 0 9 1 88 1
4 0 162136 13607604 906324 20947468 0 0 0 142 10623 12277 15 3 82 0
4 0 162136 13606516 906324 20947548 0 0 0 475 11118 13136 15 3 82 0
4 0 162136 13608300 906324 20948536 0 0 0 299 10912 12470 15 3 82 0
6 0 162136 13608716 906324 20948564 0 0 0 146 10415 11688 15 3 82 0
4 0 162136 13613492 906324 20948600 0 0 0 185 10328 11899 14 3 82 0
4 0 162136 13607044 906324 20948680 0 0 0 696 58482 110208 32 4 64 1
4 0 162136 13610108 906324 20948732 0 0 0 146 10301 11923 14 3 83 0
4 0 162136 13582140 906324 20948852 0 0 0 1340 11866 13672 15 4 81 0
4 0 162136 13566736 906324 20949876 0 0 0 180 10960 12083 15 3 82 0
具体的参数说明:
Procs(进程) r 运行队列中进程数量,这个值也可以判断是否需要增加CPU。(长期大于1) b 等待IO的进程数量。 Memory(内存) swpd 使用虚拟内存大小,如果swpd的值不为0,但是SI,SO的值长期为0,这种情况不会影响系统性能。 free 空闲物理内存大小。 buff 用作缓冲的内存大小。 cache 用作缓存的内存大小,如果cache的值大的时候,说明cache处的文件数多,如果频繁访问到的文件都能被cache处,那么磁盘的读IO bi会非常小。 Swap si 每秒从交换区写到内存的大小,由磁盘调入内存。 so 每秒写入交换区的内存大小,由内存调入磁盘。 注意:内存够用的时候,这2个值都是0,如果这2个值长期大于0时,系统性能会受到影响,磁盘IO和CPU资源都会被消耗。有些朋友看到空闲内存(free)很少的或接近于0时,就认为内存不够用了,不能光看这一点,还要结合si和so,如果free很少,但是si和so也很少(大多时候是0),那么不用担心,系统性能这时不会受到影响的。因为linux总是先把内存用光 IO bi 每秒读取的块数 bo 每秒写入的块数 注意:随机磁盘读写的时候,这2个值越大(如超出1024k),能看到CPU在IO等待的值也会越大。 system(系统) in 每秒中断数,包括时钟中断。 cs 每秒上下文切换数。 注意:上面2个值越大,会看到由内核消耗的CPU时间会越大。 CPU(以百分比表示) us 用户进程执行时间百分比(user time) us的值比较高时,说明用户进程消耗的CPU时间多,但是如果长期超50%的使用,那么我们就该考虑优化程序算法或者进行加速。 sy 内核系统进程执行时间百分比(system time) sy的值高时,说明系统内核消耗的CPU资源多,这并不是良性表现,我们应该检查原因。 wa IO等待时间百分比 wa的值高时,说明IO等待比较严重,这可能由于磁盘大量作随机访问造成,也有可能磁盘出现瓶颈(块操作)。 id 空闲时间百分比