Welcome 微信登录

首页 / 操作系统 / Linux / 对Linux进行详细的性能监控的方法

这是我们正在进行的Linux命令和性能监控系列的一部分。vmstat和iostat两个命令都适用于所有主要的类unix系统(Linux/unix/FreeBSD/Solaris)。
如果vmstat和iostat命令在你的系统中不可用,请安装sysstat软件包。vmstat,sar和iostat命令都包含在sysstat(系统监控工具)软件包中。iostat命令生成CPU和所有设备的统计信息。你可以从这个连接中下载源代码包编译安装sysstat,但是我们建议通过YUM命令进行安装。
在Linux系统中安装sysstat
   
复制代码代码如下:#yum -y install sysstat
    vmstat - 内存,进程和分页等的简要信息。
    iostat - CPU统计信息,设备和分区的输入/输出统计信息。
Linux下vmstat命令的6个范例
1. 列出活动和非活动的内存

如下范例中输出6列。vmstat的man页面中解析的每一列的意义。最重要的是内存中的free属性和交换分区中的si和so属性。
   
复制代码代码如下: [root@tecmint ~]# vmstat -a

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
rb swpd freeinact active si sobibo in cs us sy id wa st
100 810420973807062800 115 4 89 7916 9030
    Free – 空闲的内存空间
    si – 每秒从磁盘中交换进内存的数据量(以KB为单位)。
    so – 每秒从内存中交换出磁盘的数据量(以KB为单位)。
注意:如果你不带参数的执行vmstat命令,它会输出自系统启动以来的总结报告。
2. 每X秒执行vmstat,共执行N次
下面命令将会每2秒中执行一次vmstat,执行6次后自动停止执行。
   
复制代码代码如下:[root@tecmint ~]# vmstat 2 6

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
rb swpd free buffcache si sobibo in cs us sy id wa st
000 81042022064 1013680056 3 50 5703 9520
000 81041222064 10136800 0 0 16 3500 10000
000 81041222064 10136800 0 0 14 3500 10000
000 81041222064 10136800 0 0 17 3800 10000
000 81041222064 10136800 0 0 17 3500 10000
000 81041222064 10136800 0 0 18 3601 10000
3. 带时间戳的vmstat命令
带-t参数执行vmstat命令,该命令将会在每一行输出后都带一个时间戳,如下所示。
   
复制代码代码如下:[tecmint@tecmint ~]$ vmstat -t 1 5

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------ ---timestamp---
rb swpd free buffcache si sobibo in cs us sy id wa st
000 63202824992 1922440070 5 55 7813 95102012-09-02 14:57:18 IST
100 63202824992 19224400 0 017151415 94002012-09-02 14:57:19 IST
100 63190424992 19224400 0 019560005 95002012-09-02 14:57:20 IST
000 63178024992 19224400 0 015652405 95002012-09-02 14:57:21 IST
100 63165624992 19224400 0 018959205 95002012-09-02 14:57:22 IST
4. 统计各种计数器
vmstat命令的-s参数,将输出各种事件计数器和内存的统计信息。
   
复制代码代码如下:[tecmint@tecmint ~]$ vmstat -s

1030800total memory
524656used memory
277784active memory
185920inactive memory
506144free memory
26864buffer memory
310104swap cache
2064376total swap
0used swap
2064376free swap
4539 non-nice user cpu ticks
0 nice user cpu ticks
11569 system cpu ticks
329608 idle cpu ticks
5012 IO-wait cpu ticks
79 IRQ cpu ticks
74 softirq cpu ticks
0 stolen cpu ticks
336038 pages paged in
67945 pages paged out
0 pages swapped in
0 pages swapped out
258526 interrupts
392439 CPU context switches
1346574857 boot time
2309 forks
5. 磁盘统计信息
vmstat的-d参数将会输出所有磁盘的统计信息。
   
复制代码代码如下: [tecmint@tecmint ~]$ vmstat -d

disk- ------------reads------------ ------------writes----------- -----IO------
total merged sectorsmstotal merged sectorsmscursec
ram0 00 0 000 0 000
ram1 00 0 000 0 000
ram2 00 0 000 0 000
ram3 00 0 000 0 000
ram4 00 0 000 0 000
ram5 00 0 000 0 000
ram6 00 0 000 0 000
ram7 00 0 000 0 000
ram8 00 0 000 0 000
ram9 00 0 000 0 000
ram1000 0 000 0 000
ram1100 0 000 0 000
ram1200 0 000 0 000
ram1300 0 000 0 000
ram1400 0 000 0 000
ram1500 0 000 0 000
loop000 0 000 0 000
loop100 0 000 0 000
loop200 0 000 0 000
loop300 0 000 0 000
loop400 0 000 0 000
loop500 0 000 0 000
loop600 0 000 0 000
loop700 0 000 0 000
sr000 0 000 0 000
sda 7712 5145668732409619 3282288842574026445660126
dm-0 115780659242 1113017321630257384 84600260126
dm-1 32402592384500 0 002
6. 以MB为单位输出统计信息
vmstat的-S和-M参数(大写和MB)将会以MB为单位输出。vmstat默认以KB为单位输出统计信息。
   
复制代码代码如下:[root@tecmint ~]# vmstat -S M 1 5

procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
rb swpd free buffcache si sobibo in cs us sy id wa st
000346 534760095 8 42 5502 9620
000346 5347600 0 0 12 1500 10000
000346 5347600 0 0 32 6200 10000
000346 5347600 0 0 15 1300 10000
000346 5347600 0 0 34 6101 9900
linux下的Iostat命令的6个范例
1. 输出CPU和输入/输出(I/O)的统计信息

不带参数的iostat命令将会输出CPU和每个分区的输出/输出的统计信息,如下所示。
   
复制代码代码如下:[root@tecmint ~]# iostat

Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012_i686_(1 CPU)

avg-cpu:%user %nice %system %iowait%steal %idle
0.120.011.542.080.00 96.24

Device:tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
sda 3.59 161.0213.48108600290882
dm-05.76 159.7113.47107715490864
dm-10.05 0.38 0.00 25760
2. 只输出CPU的统计信息
iostat命令的-c参数仅输出CPU的统计信息,如下所示。
   
复制代码代码如下: [root@tecmint ~]# iostat -c

Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012_i686_(1 CPU)

avg-cpu:%user %nice %system %iowait%steal %idle
0.120.011.471.980.00 96.42
3. 只输出磁盘的输入/输出统计信息
iostat命令的-d参数仅输出磁盘的所有分区的输入/输出的统计信息,如下所示。
   
复制代码代码如下:[root@tecmint ~]# iostat -d

Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012_i686_(1 CPU)

Device:tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
sda 3.35 149.8112.66108600291746
dm-05.37 148.5912.65107715491728
dm-10.04 0.36 0.00 25760
4. 只输出某个磁盘的输入/输出统计信息
在默认情况下iostat命令会输出所有分区的统计信息,但是若在iostat命令后加上-p参数和磁盘设备名,该命令将会仅输出列出的磁盘的输入/输出统计信息,如下所示。
   
复制代码代码如下: [root@tecmint ~]# iostat -p sda

Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012_i686_(1 CPU)

avg-cpu:%user %nice %system %iowait%steal %idle
0.110.011.441.920.00 96.52

Device:tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
sda 3.32 148.5212.55108600291770
sda10.07 0.56 0.00 4120 18
sda23.22 147.7912.55108065091752
5. 输出逻辑卷管理(LVM)的统计信息
iostat命令的-N(大写)参数将会输出LVM(LCTT译注:LVM是linux环境下对磁盘分区进行管理的一种机制,是磁盘分区和文件系统间的一个逻辑层)的统计信息,如下所示。
   
复制代码代码如下:[root@tecmint ~]# iostat -N

Linux 2.6.32-279.el6.i686 (tecmint.com) 09/03/2012_i686_(1 CPU)

avg-cpu:%user %nice %system %iowait%steal %idle
0.110.011.391.850.00 96.64

Device:tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
sda 3.20 142.8412.16108600292466
vg_tecmint-lv_root 5.13 141.6812.16107715492448
vg_tecmint-lv_swap 0.04 0.34 0.00 25760
6. iostat版本信息
iostat的-V(大写)参数将会输出iostat的版本信息,如下所示。
   
复制代码代码如下: [root@tecmint ~]# iostat -V

sysstat version 9.0.4
(C) Sebastien Godard (sysstatorange.fr)
注意:vmstat和iostat的输出中包含多列的数据和标志,限于篇幅无法在本文中进行详细的解析。如果你想知道更多的信息,请查看vmstat和iostat的man帮助手册。如果你觉得本文对你有价值,请在下面的评论框中与你的朋友分享。