vmstat输出

 
 
1、linux系统下vmstat输出
 
vmstat的输出分为以下几种模式:
 
(1)、VM MODE (普通选项)
(2)、DISK MODE(-d选项)
(3)、DISK PARTITION MODE(-p选项)
(4)、SLAB MODE (-m选项)
 
(1)、VM MODE
 
  1. # vmstat 2 5
  2. procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------
  3. r b swpd free buff cache si so bi bo in cs us sy id wa st
  4. 0 0 0 15117732 162184 1071304 0 0 0 2 0 1 0 0 100 0 0
  5. 0 0 0 15117732 162184 1071304 0 0 0 62 1022 114 0 0 100 0 0
  6. 0 0 0 15117732 162184 1071304 0 0 0 24 1023 115 0 0 100 0 0
  7. 0 0 0 15117732 162184 1071304 0 0 0 24 1022 118 0 0 100 0 0
  8. 0 0 0 15117732 162184 1071304 0 0 0 14 1021 112 0 0 100 0 0
Procs
       r: The number of processes waiting for run time.(等待运行的进程数)
  1. r 列表示运行和等待cpu时间片的进程数,如果长期大于1,说明cpu不足,需要增加cpu。
       b: The number of processes in uninterruptible sleep.(不中断进程数)
  1. b 列表示在等待资源的进程数,比如正在等待I/O、或者内存交换等。
Memory
       swpd: the amount of virtual memory used.(使用的虚拟内存数)
  1. swpd 切换到内存交换区的内存数量(k表示)。如果swpd的值不为0,或者比较大,比如超过了100m,只要si、so的值长期为0,系统性能还是正常
       free: the amount of idle memory.(空闲内存)
  1. free 当前的空闲页面列表中内存数量(k表示)
       buff: the amount of memory used as buffers.(用作buffer的内存数量)
  1. buff 作为buffer cache的内存数量,一般对块设备的读写才需要缓冲。
       cache: the amount of memory used as cache.(用作cache的内存数量)
  1. cache: 作为page cache的内存数量,一般作为文件系统的cache,如果cache较大,说明用到cache的文件较多,如果此时IO中bi比较小,说明文件系统效率比较好。
       inact: the amount of inactive memory. (-a option)(非活动内存)
       active: the amount of active memory. (-a option)(活动中的内存)
Swap
       si: Amount of memory swapped in from disk (/s).(从硬盘中导进内存的swap数量,单位:KB/秒)
       so: Amount of memory swapped to disk (/s).(导入硬盘的swap数量,单位:KB/秒)
IO
       bi: Blocks received from a block device (blocks/s).(来自块设备的块数,单位:块/秒)
       bo: Blocks sent to a block device (blocks/s).(发往块设备的块数,单位:块/秒)
System
       in: The number of interrupts per second, including the clock.(每秒中断数)
       cs: The number of context switches per second.(每秒上下文切换数)
  1. cs列表示每秒产生的上下文切换次数,如当 cs 比磁盘 I/O 和网络信息包速率高得多,都应进行进一步调查。
CPU
       These are percentages of total CPU time.(占总CPU时间的百分比)
       us: Time spent running non-kernel code. (user time, including nice time)(用户态占用CPU百分比)
  1. us 列显示了用户方式下所花费 CPU 时间的百分比。us的值比较高时,说明用户进程消耗的cpu时间多,但是如果长期大于50%,需要考虑优化用户的程序。
       sy: Time spent running kernel code. (system time)(内核态占用CPU百分比)
  1. sy 列显示了内核进程所花费的cpu时间的百分比。这里us + sy的参考值为80%,如果us+sy 大于 80%说明可能存在CPU不足。
       id: Time spent idle. Prior to Linux 2.5.41, this includes IO-wait time.(空闲CPU百分比)
       wa: Time spent waiting for IO. Prior to Linux 2.5.41, included in idle.(IO等待占CPU百分比)
  1. wa 列显示了IO等待所占用的CPU时间的百分比。这里wa的参考值为30%,如果wa超过30%,说明IO等待严重,这可能是磁盘大量随机访问造成的,也可能磁盘或者磁盘访问控制器的带宽瓶颈造成的(主要是块操作)。
       st: Time stolen from a virtual machine. Prior to Linux 2.6.11, unknown.(从一个虚拟机被盗的时间)(没明白)
 
(2)、DISK MODE
 
  1. # vmstat -d
  2. disk- ------------reads------------ ------------writes----------- -----IO------
  3. total merged sectors ms total merged sectors ms cur sec
  4. ram0 0 0 0 0 0 0 0 0 0 0
  5. ......
  6. ram15 0 0 0 0 0 0 0 0 0 0
  7. sda 86716 11900 2652279 209257 7464061 17760678 201798334 105591331 0 41193
  8. sr0 0 0 0 0 0 0 0 0 0 0
  9. md0 0 0 0 0 0 0 0 0 0 0
Reads
       total: Total reads completed successfully(成功读取数)
       merged: grouped reads (resulting in one I/O)(分组读取数)
       sectors: Sectors read successfully(成功读取扇区数)
       ms: milliseconds spent reading(读取花费毫秒数)
Writes
       total: Total writes completed successfully(成功写入数)
       merged: grouped writes (resulting in one I/O)(分组写入数)
       sectors: Sectors written successfully(成功写入扇区数)
       ms: milliseconds spent writing(写入花费毫秒数)
IO
       cur: I/O in progress(I/O进展)(没明白)
       s: seconds spent for I/O(I/O花费时间)
 
(3)、DISK PARTITION MODE
 
  1. # vmstat -p /dev/sda1
  2. sda1 reads    read sectors    writes    requested writes
  3. 957       1918           19         38
 reads: Total number of reads issued to this partition(对这个分区的read的总数)
 read sectors: Total read sectors for partition (该分区读取扇区总数)
 writes : Total number of writes issued to this partition(对这个分区的write的总数)
 requested writes: Total number of write requests made for partition(对该分区写请求的总数)
 
(4)、SLAB MODE
 
  1. # vmstat -m
  2. Cache Num Total Size Pages
  3. nfs_direct_cache 0 0 76 50
  4. nfs_write_data 36 42 512 7
  5. nfs_read_data 32 36 448 9
  6. nfs_inode_cache 7 12 668 6
  7. nfs_page 0 0 64 59
  8. fscache_cookie_jar 2 84 44 84
  9. rpc_buffers 8 8 2048 2
.....
Cache: Cache name(Cache 名字)
Num: Number of currently active objects(当前活动对象个数)
Total: Total number of available objects(可用对象总数)
Size:  Size of each object(每个对象的大小)
Pages: Number of pages with at least one active object(至少有一个活动对象的页数)
 
另外man page值还提到了totpages和pslab,在-m选项的结果中没有体现出来。
 
totpages: Total number of allocated pages( 分配的页面总数)
pslab: Number of pages per slab(每个slab 页面的数量)
 
2、Solaris下vmstat输出请参阅
 
3、AIX下vmstat输出请参阅
 
4、参考资料:

Linux性能分析 vmstat输出的更多相关文章

  1. Linux性能分析 vmstat基本语法

    vmstat      vmstat 统计虚拟内存信息,可以对操作系统的proc.memory.CPU.IO等信息进行统计以呈现给用户.   根据操作系统的不同,vmstat的输出结果会有不同.大家可 ...

  2. linux系统性能调优第一步——性能分析(vmstat)

    linux系统性能调优第一步--性能分析(vmstat) 分类: LINUX 性能调优的第一步是性能分析,下面从性能分析着手进行一些介绍,尤其对linux性能分析工具vmstat的用法和实践进行详细介 ...

  3. Linux 性能分析工具汇总合集

    出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望,因此整理了这篇文章.本文也可以作为检验基础知识的指标,另外文章涵盖了一个系统的方方面面.如果没有完善的计算机系统知识,网络知识和操作系统知识, ...

  4. Linux性能分析的前60000毫秒【转】

    Linux性能分析的前60000毫秒 为了解决性能问题,你登入了一台Linux服务器,在最开始的一分钟内需要查看什么? 在Netflix我们有一个庞大的EC2 Linux集群,还有非常多的性能分析工具 ...

  5. [转]Linux性能分析工具汇总合集

    出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望,因此整理了这篇文章.本文也可以作为检验基础知识的指标,另外文章涵盖了一个系统的方方面面.如果没有完善的计算机系统知识,网络知识和操作系统知识, ...

  6. 超全整理!Linux性能分析工具汇总合集

    转自:http://rdc.hundsun.com/portal/article/731.html?ref=myread 出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望,因此整理了这篇文章. ...

  7. (转)超全整理!Linux性能分析工具汇总合集

    超全整理!Linux性能分析工具汇总合集 原文:http://rdc.hundsun.com/portal/article/731.html 出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望, ...

  8. Linux性能分析命令工具汇总

    转自:http://rdc.hundsun.com/portal/article/731.html?ref=myread 出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望,因此整理了这篇文章. ...

  9. Linux 性能分析 工具命令

    背景知识:具备背景知识是分析性能问题时需要了解的.比如硬件 cache:再比如操作系统内核.应用程序的行为细节往往是和这些东西互相牵扯的,这些底层的东西会以意想不到的方式影响应用程序的性能,比如某些程 ...

随机推荐

  1. 一些java的部署执行编译等命令

    编译: javac 参数 -d 指定编译后文件的位置 java 执行java文件 java生成jar文件 java执行jar文件 java生成war文件 war包是一种将web程序捆绑到单个文件上的一 ...

  2. maven多环境配置

    我们在开发项目的时候,往往会有好几个环境.比如开发.预发布(测试).产品,每个环境一般用到配置都不一样,最典型的就是数据库,开发的数据库与产品的数据库肯定是不一样的,如果要多个环境的切换就得改配置,这 ...

  3. php 递归调用又一种方法

     public static function encodeXml($data){        $attr = $xml = "";        foreach($data a ...

  4. kbmMW 5.06.20试用笔记

    1.kbmMWConfiguration自动备份配置文件的问题还没有修正. 下面是以前写过的内容,再一次在新闻组中提出这个问题: kbmMW提供一个强大的配置信息管理对象,前期译过这个对象的介绍,在使 ...

  5. FMX StringGrid向上滑动自动加载记录(二)

    写完FMX StringGrid向上滑动自动加载记录(一)自己也觉得不理想,实现的别扭与复杂,现在找到更好的实现方法,原来,StringGrid从基类TCustomPresentedScrollBox ...

  6. Python GIL 系列之再谈Python的GIL

    1. 之前写过一篇<通过实例认识Python的GIL>的文章,感觉有些意犹未尽 2. 这次对例子作了些扩展,进一步的分析GIL对Python程序的影响 2.1 先来看例子: [python ...

  7. Linux环境下 多线程下载 (Python 实现版)

    本文是多年前学习编程时参照一个网友程序的基础之上改写的, 采用Python语音编写, 多线程下载功能, 可以有效提高Linux下原有下载工具中的一些不足,以下给出具体代码. #!/usr/bin/py ...

  8. opencv-python教程学习系列4-opencv绘图函数

    前言 opencv-python教程学习系列记录学习python-opencv过程的点滴,本文主要介绍opencv绘图函数,坚持学习,共同进步. 系列教程参照OpenCV-Python中文教程: 系统 ...

  9. Unity 3D换装系统教程/Demo

    Unity3D换装系统教程 本文提供全流程,中文翻译.Chinar坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) 1 Costume Change ...

  10. python3 获取当前调用函数名

    import sys funcName = sys._getframe().f_back.f_code.co_name #获取调用函数名lineNumber = sys._getframe().f_b ...