vmstat命令

来源:互联网 发布:淘宝手机端主图大小 编辑:程序博客网 时间:2024/06/05 11:14

Virtual Memory Statistics ( vmstat )   vmstat 是报告关于进程,虚拟内存,磁盘,CPU活动的一个统计报告.
在一个多CPU系统中,vmstat统计所有个数的CPU的平均输出.为每个进程进行统计.没有参数时,vmstat显示每一行是自从系统启动以后的虚拟内存的活动情况.(注:vmstat输出的第一行对于实施统计没有意义)
用法:
基本的用法是vmstat   interval count
option: 指定我们所需要的输出选项比如: paging   -p , cache -c ,.interrupt -i   等等(还有一个比较有用的是S),更加具体的vmstat的参数情况可以参照man手册和系统管理员手册的相应说明.
如果没有指定参数,输出的信息是关于process , memory , paging , disk ,interrupts & cpu的显示.
interval 是在两个输出结果输出的时候给予的间隔时间.. vmstat 4   是给予4秒的间隔.
count   是你需要的输出的数据量.ivmstat 4 5   是间隔4秒输出5次数据.
下面是关于一些参数的描述:
procs          r     in run queue         b     blocked for resources I/O, paging etc.         w     swapped    memory (in Kbytes)             swap -   amount   of   swap space currently available                          free - size of the free list     page ( in units per second).          re page reclaims -   see   -S   option   for   how   this field is modified.          mf minor faults -   see   -S   option   for   how this field is modified.          pi kilobytes paged in          po kilobytes paged out          fr kilobytes freed          de anticipated short-term memory shortfall (Kbytes)          sr pages scanned by clock algorithm    disk   ( operations per second )           There are   slots for up to four disks, labeled with a single letter and number.           The letter indicates   the   type   of   disk   (s = SCSI, i = IPI, etc) . The number is            the logical unit number.    faults         in (non clock) device interrupts          sy system calls          cs CPU context switches    cpu   - breakdown of percentage usage of CPU   time.   On multiprocessors   this is an average across all processors.          us user time          sy system time          id idle time
CPU问题现象:
1.) 如果在processes中运行的序列(process r)是连续的大于在系统中的CPU的个数表示系统现在运行比较慢,有多数的进程等待CPU.
2.) 如果r的输出数大于系统中可用CPU个数的4倍的话,则系统面临着CPU短缺的问题,或者是CPU的速率过低,系统中有多数的进程在等待CPU,造成系统中进程运行过慢.
3.) 如果空闲时间(cpu id)持续为0并且系统时间(cpu sy)是用户时间的两倍(cpu us) 系统则面临着CPU资源的短缺.
  
解决办法:
当发生以上问题的时候请先调整应用程序对CPU的占用情况.使得应用程序能够更有效的使用CPU.同时可以考虑增加更多的CPU.   关于CPU的使用情
况还可以结合mpstat,   ps aux top   prstat
–a等等一些相应的命令来综合考虑关于具体的CPU的使用情况,和那些进程在占用大量的CPU时间.一般情况下,应用程序的问题会比较大一些.比如一些SQL语句不合理等等都会造成这样的现象.
  
  
内存问题现象:
内存的瓶颈是由scan rate (sr)来决定的.scan rate是通过每秒的始终算法来进行页扫描的.如果scan
rate(sr)连续的大于每秒200页则表示可能存在内存缺陷.同样的如果page项中的pi和po这两栏表示每秒页面的调入的页数和每秒调出的页数.
如果该值经常为非零值,也有可能存在内存的瓶颈,当然,如果个别的时候不为0的话,属于正常的页面调度这个是虚拟内存的主要原理.
  
解决办法:
1.调节applications & servers使得对内存和cache的使用更加有效.
2.增加系统的内存.
3. Implement priority paging in s in pre solaris 8 versions by adding line "set priority paging=1" in
/etc/system. Remove this line if upgrading from Solaris 7 to 8 & retaining old /etc/system file.
关于内存的使用情况还可以结ps aux top   prstat
–a等等一些相应的命令来综合考虑关于具体的内存的使用情况,和那些进程在占用大量的内存.一般情况下,如果内存的占用率比较高,但是,CPU的占用很低的时候,可以考虑是有很多的应用程序占用了内存没有释放,但是,并没有占用CPU时间,可以考虑应用程序,对于未占用CPU时间和一些后台的程序,释放内存的占用.

写的不对的地方欢迎朋友帮忙指出。谢谢,并且帮助补充。谢谢!!!
                
               

1 观察磁盘活动情况

磁盘活动情况主要从以下几个指标了解:
bi:表示从磁盘每秒读取的块数(blocks/s)。数字越大,表示读磁盘的活动越多。
bo:表示每秒写到磁盘的块数(blocks/s)。数字越大,表示写磁盘的活动越多。
wa:cpu等待磁盘I/O(未决的磁盘IO)的时间比例。数字越大,表示文件系统活动阻碍cpu的情况越严重,因为cpu在等待慢速的磁盘系统提供数据。wa为0是最理想的。如果wa经常大于10,可能文件系统就需要进行性能调整了。

   

2 观察cpu活动情况

vmstat比top更能反映出cpu的使用情况:
us:用户程序使用cpu的时间比例。这个数字越大,表示用户进程越繁忙。
sy:系统调用使用cpu的时间比例。注意,NFS由于是在内核里面运行的,所以NFS活动所占用的cpu时间反映在sy里面。这个数字经常很大的话,就需要注意是否某个内核进程,比如NFS任务比较繁重。如果us和sy同时都比较大的话,就需要考虑将某些用户程序分离到另外的服务器上面,以免互相影响。
id:cpu空闲的时间比例。
wa:cpu等待未决的磁盘IO的时间比例。  
来源:http://apps.hi.baidu.com/share/detail/16230654
原创粉丝点击