码迷,mamicode.com
首页 > 其他好文 > 详细

vmstat 查看系统负载情况

时间:2015-06-29 22:00:41      阅读:120      评论:0      收藏:0      [点我收藏+]

标签:

$ vmstat
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 1  4 329796  26040   4528 3379824    1    1    50   160   36   17  2 10 85  3  0

procs
r 列表示运行和等待cpu时间片的进程数,如果长期大于1,说明cpu不足,需要增加cpu。
b 列表示在等待资源的进程数,比如正在等待I/O、或者内存交换等。
cpu 表示cpu的使用状态
us 列显示了用户方式下所花费 CPU 时间的百分比。us的值比较高时,说明用户进程消耗的cpu时间多,但是如果长期大于50%,需要考虑优化用户的程序。
sy 列显示了内核进程所花费的cpu时间的百分比。这里us + sy的参考值为80%,如果us+sy 大于 80%说明可能存在CPU不足。
wa 列显示了IO等待所占用的CPU时间的百分比。这里wa的参考值为30%,如果wa超过30%,说明IO等待严重,这可能是磁盘大量随机访问造成的,也可能磁盘或者磁盘访问控制器的带宽瓶颈造成的(主要是块操作)。
id 列显示了cpu处在空闲状态的时间百分比
system 显示采集间隔内发生的中断数
in 列表示在某一时间间隔中观测到的每秒设备中断数。
cs列表示每秒产生的上下文切换次数,如当 cs 比磁盘 I/O 和网络信息包速率高得多,都应进行进一步调查。
memory
swpd 切换到内存交换区的内存数量(k表示)。如果swpd的值不为0,或者比较大,比如超过了100m,只要si、so的值长期为0,系统性能还是正常
free 当前的空闲页面列表中内存数量(k表示)
buff 作为buffer cache的内存数量,一般对块设备的读写才需要缓冲。
cache: 作为page cache的内存数量,一般作为文件系统的cache,如果cache较大,说明用到cache的文件较多,如果此时IO中bi比较小,说明文件系统效率比较好。
swap
si 由内存进入内存交换区数量。
so由内存交换区进入内存数量。
IO
bi 从块设备读入数据的总量(读磁盘)(每秒kb)。
bo 块设备写入数据的总量(写磁盘)(每秒kb)
这里我们设置的bi+bo参考值为1000,如果超过1000,而且wa值较大应该考虑均衡磁盘负载,可以结合iostat输出来分析。

vmstat 能够提供进程,内存,分页,块I/O,traps和CPU活动相关信息。vmstat 命令可以显示平均值或实际取样值。使用频率和取样时间等参数启用
 模式
    命令参数
              -V  显示版本
              -n  只在开始时显示一次各字段名称
              -a  显示活跃和非活跃内存
              -d  显示磁盘相关统计信息
              -D  以表格的形式显示磁盘信息
              -p  显示指定磁盘分区相关信息
              -s   显示内存相关统计信息及多种活动数量
                  delay:刷洗时间间隔。如果不指定,只显示一条结果
                  count:刷新次数,如不指定刷新次数,但不指定刷新时间间隔,默认为无穷
              -m 显示slabinfo
              -t 显示统计信息的同时打印出时间,该参数和上面的参数同时使用
              -S 指定单位显示,如,k,K,m,M
 
二 命令信息详解
 
[root@localhost ~]# 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
 1  0      0 403216  24820  67964    0    0     7     2   19   47  0  1 99  0  0 
 0  0      0 403208  24820  67964    0    0     0     0   16   20  0  0 100  0  0 
 0  0      0 403208  24820  67964    0    0     0     0   14   17  0  0 100  0  0 
 0  0      0 403208  24820  67964    0    0     0     0   11   13  0  0 100  0  0 
 0  0      0 403208  24820  67964    0    0     0     0   14   15  0  0 100  0  0 
注释:vmstat输出结果中第一行展示的是自最后一次启动以来的平均值,所以此行可以忽略。
输出栏位如下:
 Process(procs)
  r:等待运行时间的进程数
  b:处于不可中断睡眠状态的进程数
  w: 被交换出去的看一下的进程数。此数是由linux 计算得出的,但是Linux 并不好进交换空间
Memory
 swpd:虚拟内存使用量(KB)
 free:空闲内存量(KB)
 buffer:用作buffer的内存量(KB)
 cache:用作cache的内存量(KB)
Swap
   si:从硬盘交换到内存的数量(KBps)
   so:交换到硬盘的内存量(KBps)
IO
  bi:发送到块设备的块的数量(block/s)
  bo: 从块设备获取的块的数量(block/s)
System
  in:  每秒钟的中断数量,包括时钟中断
  cs:每秒钟上下文交换的数量
 
CPU(整个CPU时间的百分比)
 us:花费在非内核代码的CPU 时间 (用户时间,包括Nice时间)
 sy:花费在内核代码的CPU 时间(系统时间)
 id:空闲时间
 wa:IO等待时间
 标准情况下r和b值
  r<5,b≈0
 如果user%+sys%< 70%,表示系统性能较好;如果user%+sys%>=85%,表示系统性能比较糟糕
  user%表示CPU处在用户模式下的时间百分比。
 sys%表示CPU处在系统模式下的时间百分比。

vmstat 查看系统负载情况

标签:

原文地址:http://www.cnblogs.com/shengs/p/4608862.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!