Chinaunix首页 | 论坛 | 博客
  • 博客访问: 577826
  • 博文数量: 94
  • 博客积分: 1452
  • 博客等级: 上尉
  • 技术积分: 982
  • 用 户 组: 普通用户
  • 注册时间: 2010-05-06 15:38
文章分类

全部博文(94)

文章存档

2018年(3)

2014年(26)

2013年(11)

2012年(3)

2011年(43)

2010年(8)

分类: LINUX

2014-05-23 15:36:09

生成 文本更改
#vmstat -1 >/usr/local/src/stat.txt

#vi /usr/local/src/stat.txt

输入:
:%s/[ ]\{1,\}/,/g

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
15  0      0 10198372 256532 2270052    0    0     0     3    1    0  0  0 99  0  0 
12  0      0 10195592 256532 2270128    0    0     0     0 27345 21333 77 19  4  0  0 
13  0      0 10194748 256532 2270196    0    0     0     0 28003 20700 78 18  3  0  0
替换后如下
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
,r,b,swpd,free,buff,cache,si,so,bi,bo,in,cs,us,sy,id,wa,st
15,0,0,10198372,256532,2270052,0,0,0,3,1,0,0,0,99,0,0    
12,0,0,10195592,256532,2270128,0,0,0,0,27345,21333,77,19,4,0,0   
13,0,0,10194748,256532,2270196,0,0,0,0,28003,20700,78,18,3,0,0  


vmstat基础知识 Vmstat可以实时查看系统资源使用情况,如内存、CPU、IO等,如下图所示: 
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
15  0      0 10198372 256532 2270052    0    0     0     3    1    0  0  0 99  0  0
12  0      0 10195592 256532 2270128    0    0     0     0 27345 21333 77 19  4  0  0
13  0      0 10194748 256532 2270196    0    0     0     0 28003 20700 78 18  3  0  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作为buffercache的内存数量,一般对块设备的读写才需要缓冲。
cache:作为pagecache的内存数量,一般作为文件系统的cache,如果cache较大,说明用到cache的文件较多,如果此时IO中bi比较小,说明文件系统效率比较好。

swap
si由内存进入内存交换区数量。
so由内存交换区进入内存数量。


IO 
bi从块设备读入数据的总量(读磁盘)(每秒kb)。
bo块设备写入数据的总量(写磁盘)(每秒kb) 这里我们设置的bi+bo参考值为1000,如果超过1000,而且wa值较大应该考虑均衡磁盘负载,可以结合iostat输出来分析。

一般最常用就是vmstat  T表示每隔一段时间采集一次数据,T单位为秒。

如果想每隔一段时间采集一次,并想固定采集次数,可以使用vmstat????T????count其中count就表示

采集的次数。

如果想每隔一段时间采集一次,并想固定采集次数,可以使用vmstat????T????count其中count就表示

采集的次数。

如果想每隔一段时间采集一次,并想固定采集次数,可以使用vmstat????T????count其中count就表示

采集的次数。

如果想每隔一段时间采集一次,并想固定采集次数,可以使用vmstat????T????count其中count就表示

采集的次数。

如果想每隔一段时间采集一次,并想固定采集次数,可以使用vmstat T  count其中count就表示采集的次数。
更常用的的是将采集的文件输出到文件中,如将每5秒采集一次,共采集100次的数据输出到文件resource.txt文件中,就用vmstat 5 100 >resource.txt即可。

生成 文本更改
#vmstat -1 >/usr/local/src/stat.txt

#vi /usr/local/src/stat.txt

输入:
:%s/[ ]\{1,\}/,/g

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
15  0      0 10198372 256532 2270052    0    0     0     3    1    0  0  0 99  0  0
12  0      0 10195592 256532 2270128    0    0     0     0 27345 21333 77 19  4  0  0
13  0      0 10194748 256532 2270196    0    0     0     0 28003 20700 78 18  3  0  0
替换后如下
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
,r,b,swpd,free,buff,cache,si,so,bi,bo,in,cs,us,sy,id,wa,st
15,0,0,10198372,256532,2270052,0,0,0,3,1,0,0,0,99,0,0    
12,0,0,10195592,256532,2270128,0,0,0,0,27345,21333,77,19,4,0,0   
13,0,0,10194748,256532,2270196,0,0,0,0,28003,20700,78,18,3,0,0  

阅读(1582) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~