vmstat 命令详解
作用:vmstat 的含义为显示虚拟内存状态(virtual memor statics),但是它可以报告关于进程,内存,I/O 等系统整体运行状态
选项:
-a 显示活动内页-f 显示启动后创建的进程总数-m 显示slab 信息-n 头信息仅显示一次-s 以表格方式显示事件计数器和内存状态-d 报告磁盘状态-p 显示指定的硬盘分区状态-S 输出信息的单位
参数
事件间隔:状态信息刷新的时间间隔次数: 显示报告的次数
实例:
vmstat 3procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----r b swpd free buff cache si so bi bo in cs us sy id wa st0 0 0 952092 10236 38704 0 0 47 3 17 24 0 0 99 0 00 0 0 952084 10236 38704 0 0 0 0 5 7 0 0 100 0 00 0 0 952084 10236 38704 0 0 0 0 5 6 0 0 100 0 00 0 0 952084 10236 38704 0 0 0 0 6 8 0 0 100 0 00 0 0 952084 10236 38704 0 0 0 0 5 6 0 0 100 0 0字段说明Proc (进程)*r : 运行队列中进程数量, 这个值也可以判断是否需要增加CPU。(长期大于1)*b : 等待IO 的进程数量Memory (内存)*swpd : 使用虚拟内存大小,如果swpd 的值不为0 , 但是SI, SO的值长期为0, 不会影响系统性能*free : 空闲物理内存大小*buff : 用作缓冲的内存大小*cache : 用作缓存的内存大小, 如果cache的值大的时候, 说明cache处的文件数多, 如果频繁访问到的文件都被cache处, 那么磁盘的IO BI会非常小Swap*si : 每秒从交换区写到内存的大小, 由磁盘调入内存. swapped in from disk*so : 每秒写入交换区的内存大小, 由内存调入磁盘 swapped to diskIO (现在的Linux版本块的大小为1kb)*bi : 每秒读取的块数 block received from a block device*bo: 每秒写入的块数 block sent to a block device随机磁盘读写的时候, 这两个值越大能看到CPU的IO等待值也会变大System*in : 每秒中断数*cs : 每秒上下文切换数CPU*us : 用户进程执行时间百分比(user time),us 的值比较高时,说明用户进程消耗的CPU时间多, 但是如果长期超50% 的使用,那么就应该考虑优化程序算法或者加速*sy : 内核系统进程执行时间百分比(system time)sy 的值高时, 说明系统内核消耗的CPU资源多, 需要检查原因*wa : IO 等待时间百分比wa 的值高时, 说明IO 等待比较严重, 这可能是由于磁盘大量随机访问造成, 也有可能是磁盘出现瓶颈*id : 空闲时间百分比文件:/proc/meminfo/proc/stat/proc/*/stat