对Linux进行详细的性能监控的方法
这是我们正在进行的Linux命令和性能监控系列的一部分。vmstat和iostat两个命令都适用于所有主要的类unix系统(Linux/unix/FreeBSD/Solaris)。
如果vmstat和iostat命令在你的系统中不可用,请安装sysstat软件包。vmstat,sar和iostat命令都包含在sysstat(系统监控工具)软件包中。iostat命令生成CPU和所有设备的统计信息。你可以从这个连接中下载源代码包编译安装sysstat,但是我们建议通过YUM命令进行安装。
在Linux系统中安装sysstat
vmstat - 内存,进程和分页等的简要信息。
iostat - CPU统计信息,设备和分区的输入/输出统计信息。
Linux下vmstat命令的6个范例
1. 列出活动和非活动的内存
如下范例中输出6列。vmstat的man页面中解析的每一列的意义。最重要的是内存中的free属性和交换分区中的si和so属性。
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
r bswpdfree inact activesiso bi boincs us sy id wa st
1 00 810420 97380 70628 0 0115 48979 1 6 90 3 0
Free – 空闲的内存空间
si – 每秒从磁盘中交换进内存的数据量(以KB为单位)。
so – 每秒从内存中交换出磁盘的数据量(以KB为单位)。
注意:如果你不带参数的执行vmstat命令,它会输出自系统启动以来的总结报告。
2. 每X秒执行vmstat,共执行N次
下面命令将会每2秒中执行一次vmstat,执行6次后自动停止执行。
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
r bswpdfreebuff cachesiso bi boincs us sy id wa st
0 00 810420 22064 101368 0 0 56 35057 0 3 95 2 0
0 00 810412 22064 101368 0 0 0 01635 0 0 100 0 0
0 00 810412 22064 101368 0 0 0 01435 0 0 100 0 0
0 00 810412 22064 101368 0 0 0 01738 0 0 100 0 0
0 00 810412 22064 101368 0 0 0 01735 0 0 100 0 0
0 00 810412 22064 101368 0 0 0 01836 0 1 100 0 0
3. 带时间戳的vmstat命令
带-t参数执行vmstat命令,该命令将会在每一行输出后都带一个时间戳,如下所示。
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu------ ---timestamp---
r bswpdfreebuff cachesiso bi boincs us sy id wa st
0 00 632028 24992 192244 0 0 70 55578 1 3 95 1 0 2012-09-02 14:57:18 IST
1 00 632028 24992 192244 0 0 0 0 171 514 1 5 94 0 0 2012-09-02 14:57:19 IST
1 00 631904 24992 192244 0 0 0 0 195 600 0 5 95 0 0 2012-09-02 14:57:20 IST
0 00 631780 24992 192244 0 0 0 0 156 524 0 5 95 0 0 2012-09-02 14:57:21 IST
1 00 631656 24992 192244 0 0 0 0 189 592 0 5 95 0 0 2012-09-02 14:57:22 IST
4. 统计各种计数器
vmstat命令的-s参数,将输出各种事件计数器和内存的统计信息。
1030800 total memory
524656 used memory
277784 active memory
185920 inactive memory
506144 free memory
26864 buffer memory
310104 swap cache
2064376 total swap
0 used swap
2064376 free 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参数将会输出所有磁盘的统计信息。
disk- ------------reads------------ ------------writes----------- -----IO------
total merged sectorsms total merged sectorsms cur sec
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
sr0 00 0 000 0 000
sda 77125145 668732 4096193282 28884 257402 6445660 126
dm-0115780 659242 1113017 321630 257384 84600260 126
dm-1 3240 2592 384500 0 002
6. 以MB为单位输出统计信息
vmstat的-S和-M参数(大写和MB)将会以MB为单位输出。vmstat默认以KB为单位输出统计信息。
procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu-----
r bswpdfreebuff cachesiso bi boincs us sy id wa st
0 00 346 53 476 0 0 95 84255 0 2 96 2 0
0 00 346 53 476 0 0 0 01215 0 0 100 0 0
0 00 346 53 476 0 0 0 03262 0 0 100 0 0
0 00 346 53 476 0 0 0 01513 0 0 100 0 0
0 00 346 53 476 0 0 0 03461 0 1 99 0 0
linux下的Iostat命令的6个范例
1. 输出CPU和输入/输出(I/O)的统计信息
不带参数的iostat命令将会输出CPU和每个分区的输出/输出的统计信息,如下所示。
Linux 2.6.32-279.el6.i686 (tecmint.com)09/03/2012_i686_ (1 CPU)
avg-cpu: %user%nice %system %iowait %steal%idle
0.12 0.01 1.54 2.08 0.0096.24
Device:tpsBlk_read/sBlk_wrtn/sBlk_readBlk_wrtn
sda3.59 161.02 13.48 108600290882
dm-0 5.76 159.71 13.47 107715490864
dm-1 0.050.380.00 2576 0
2. 只输出CPU的统计信息
iostat命令的-c参数仅输出CPU的统计信息,如下所示。
Linux 2.6.32-279.el6.i686 (tecmint.com)09/03/2012_i686_ (1 CPU)
avg-cpu: %user%nice %system %iowait %steal%idle
0.12 0.01 1.47 1.98 0.0096.42
3. 只输出磁盘的输入/输出统计信息
iostat命令的-d参数仅输出磁盘的所有分区的输入/输出的统计信息,如下所示。
Linux 2.6.32-279.el6.i686 (tecmint.com)09/03/2012_i686_ (1 CPU)
Device:tpsBlk_read/sBlk_wrtn/sBlk_readBlk_wrtn
sda3.35 149.81 12.66 108600291746
dm-0 5.37 148.59 12.65 107715491728
dm-1 0.040.360.00 2576 0
4. 只输出某个磁盘的输入/输出统计信息
在默认情况下iostat命令会输出所有分区的统计信息,但是若在iostat命令后加上-p参数和磁盘设备名,该命令将会仅输出列出的磁盘的输入/输出统计信息,如下所示。
Linux 2.6.32-279.el6.i686 (tecmint.com)09/03/2012_i686_ (1 CPU)
avg-cpu: %user%nice %system %iowait %steal%idle
0.11 0.01 1.44 1.92 0.0096.52
Device:tpsBlk_read/sBlk_wrtn/sBlk_readBlk_wrtn
sda3.32 148.52 12.55 108600291770
sda1 0.070.560.00 412018
sda2 3.22 147.79 12.55 108065091752
5. 输出逻辑卷管理(LVM)的统计信息
iostat命令的-N(大写)参数将会输出LVM(LCTT译注:LVM是linux环境下对磁盘分区进行管理的一种机制,是磁盘分区和文件系统间的一个逻辑层)的统计信息,如下所示。
Linux 2.6.32-279.el6.i686 (tecmint.com)09/03/2012_i686_ (1 CPU)
avg-cpu: %user%nice %system %iowait %steal%idle
0.11 0.01 1.39 1.85 0.0096.64
Device:tpsBlk_read/sBlk_wrtn/sBlk_readBlk_wrtn
sda3.20 142.84 12.16 108600292466
vg_tecmint-lv_root 5.13 141.68 12.16 107715492448
vg_tecmint-lv_swap 0.040.340.00 2576 0
6. iostat版本信息
iostat的-V(大写)参数将会输出iostat的版本信息,如下所示。
sysstat version 9.0.4
(C) Sebastien Godard (sysstat orange.fr)
注意:vmstat和iostat的输出中包含多列的数据和标志,限于篇幅无法在本文中进行详细的解析。如果你想知道更多的信息,请查看vmstat和iostat的man帮助手册。如果你觉得本文对你有价值,请在下面的评论框中与你的朋友分享。
版权声明:本站文章来源标注为YINGSOO的内容版权均为本站所有,欢迎引用、转载,请保持原文完整并注明来源及原文链接。禁止复制或仿造本网站,禁止在非www.yingsoo.com所属的服务器上建立镜像,否则将依法追究法律责任。本站部分内容来源于网友推荐、互联网收集整理而来,仅供学习参考,不代表本站立场,如有内容涉嫌侵权,请联系alex-e#qq.com处理。