sysstat工具包
一.sysstat工具
sysstat是一个工具包,包含有几个很有用的系统检测程序,iostat,mpstat和sar.
Turbolinux的各个版本上,都包含这个工具包.
iostat用于输出CPU,I/O系统和磁盘分区的统计信息.可以用来分析磁盘I/O,带宽等信息.
mpstat用于输出CPU的各种统计信息. 可以用来分析程序运行时在内核态和用户态的工作情况.
sar用于定时搜集系统的各种状态信息.然后可以对系统各个时间点的状态进行监控.
二.使用sysstat
1.iostat
iostat用于输出CPU和磁盘I/O相关的统计信息.
命令格式:
iostat [ -c | -d ] [ -k | -m ] [ -t ] [ -V ] [ -x ] [ device [ ... ] | ALL ] [ -p [ device | ALL ] ]
[ interval [ count ] ]
1)iostat的简单使用
iostat可以显示CPU和I/O系统的负载情况及分区状态信息.
直接执行iostat可以显示下面内容:
# iostat
Linux 2.6.9-8.11.EVAL (ts3-150.ts.cn.tlan) 08/08/2007
avg-cpu: %user %nice %sys %iowait %idle
12.01 0.00 2.15 2.30 83.54
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn
hda 7.13 200.12 34.73 640119 111076
各个输出项目的含义如下:
avg-cpu段:
%user: 在用户级别运行所使用的CPU的百分比.
%nice: nice操作所使用的CPU的百分比.
%sys: 在系统级别(kernel)运行所使用CPU的百分比.
%iowait: CPU等待硬件I/O时,所占用CPU百分比.
%idle: CPU空闲时间的百分比.
Device段:
tps: 每秒钟发送到的I/O请求数.
Blk_read /s: 每秒读取的block数.
Blk_wrtn/s: 每秒写入的block数.
Blk_read: 读入的block总数.
Blk_wrtn: 写入的block总数.
2)iostat参数说明
iostat各个参数说明:
-c 仅显示CPU统计信息.与-d选项互斥.
-d 仅显示磁盘统计信息.与-c选项互斥.
-k 以K为单位显示每秒的磁盘请求数,默认单位块.
-p device | ALL
与-x选项互斥,用于显示块设备及系统分区的统计信息.也可以在-p后指定一个设备名,如:
# iostat -p hda
或显示所有设备
# iostat -p ALL
-t 在输出数据时,打印搜集数据的时间.
-V 打印版本号和帮助信息.
-x 输出扩展信息.
3)iostat输出项目说明
Blk_read
读入块的当总数.
Blk_wrtn
写入块的总数.
kB_read/s
每秒从驱动器读入的数据量,单位为K.
kB_wrtn/s
每秒向驱动器写入的数据量,单位为K.
kB_read
读入的数据总量,单位为K.
kB_wrtn
写入的数据总量,单位为K.
rrqm/s
将读入请求合并后,每秒发送到设备的读入请求数.
wrqm/s
将写入请求合并后,每秒发送到设备的写入请求数.
r/s
每秒发送到设备的读入请求数.
w/s
每秒发送到设备的写入请求数.
rsec/s
每秒从设备读入的扇区数.
wsec/s
每秒向设备写入的扇区数.
rkB/s
每秒从设备读入的数据量,单位为K.
wkB/s
每秒向设备写入的数据量,单位为K.
avgrq-sz
发送到设备的请求的平均大小,单位是扇区.
avgqu-sz
发送到设备的请求的平均队列长度.
await
I/O请求平均执行时间.包括发送请求和执行的时间.单位是毫秒.
svctm
发送到设备的I/O请求的平均执行时间.单位是毫秒.
%util
在I/O请求发送到设备期间,占用CPU时间的百分比.用于显示设备的带宽利用率.
当这个值接近100%时,表示设备带宽已经占满.
4)iostat示例
# iostat
显示一条统计记录,包括所有的CPU和设备.
# iostat -d 2
每隔2秒,显示一次设备统计信息.
# iostat -d 2 6
每隔2秒,显示一次设备统计信息.总共输出6次.
# iostat -x hda hdb 2 6
每隔2秒显示一次hda,hdb两个设备的扩展统计信息,共输出6次.
# iostat -p sda 2 6
每隔2秒显示一次sda及上面所有分区的统计信息,共输出6次.
2.mpstat
1)mpstat简介
mpstat用于输出与CPU相关的统计信息.
mpstat命令格式:
mpstat [ -P { cpu | ALL } ] [ -V ] [ interval [ count ] ]
mpstat用于输出每一个CPU的运行状况,并会输出一个汇总的信息.
2)mpstat参数说明
interval 参数用来指定每次统计信息之间的间隔时间,单位是秒.指定0则输出自系统
启动后的一个统计信息.
count 参数用来指定产生统计信息的总数.如果不指定,mpstat将不断产生统计信息.
-P cpu | ALL
表示CPU-ID,第一个CPU为0.ALL表示输出所有CPU的统计信息.
-V 输出版本号和帮助信息.
3)mpstat各个输出项目的含义如下
CPU
CPU-ID,在多CPU系统里,每个CPU有一个ID号,第一个CPU为0.
all表示,统计信息为所有CPU的平均值.
%user
显示在用户级别运行所占用CPU总时间的百分比.
%nice
显示在用户级别,用于nice操作,所占用CPU总时间的百分比.
%system
显示在kernel级别运行所占用CPU总时间的百分比.
注意:这个值并不包括服务中断和softirq.
%iowait
显示用于等待I/O操作时,占用CPU总时间的百分比.
%irq
显示用于中断操作,占用CPU总时间的百分比.
%soft
显示用于softirq操作,占用CPU总时间的百分比.
%idle
显示CPU在空闲状态,占用CPU总时间的百分比.
intr/s
显示CPU每秒接收到的中断总数.
4)mpstat示例
# mpstat 2 5
每隔2秒输出一个统计信息,共输出5次.
mpstat -P ALL 2 5
每隔2秒输出一次所有CPU的统计信息,共输出5次.
3.sar
1)sar的简介
sar可以用来定时搜集系统信息,并输出各个时间点的统计信息.包括:CPU,磁盘I/O等信息.可以帮助
分析的系统负载状况.
sar默认将搜集的数据保存在/var/log/sysstat/saXX文件中,XX是当前日期的日.sa12表示保存的是12日的统计信息.
命令格式:
sar [ -A ] [ -b ] [ -B ] [ -c ] [ -d ] [ -H ] [ -h ] [ -i interval ] [
-q ] [ -r ] [ -R ] [ -t ] [ -u ] [ -v ] [ -V ] [ -w ] [ -W ] [ -y ] [
-n { DEV | EDEV | SOCK | FULL } ] [ -x { pid | SELF | ALL } ] [ -X {
pid | SELF | ALL } ] [ -I { irq | SUM | ALL | XALL } ] [ -P { cpu |
ALL } ] [ -o [ filename ] | -f [ filename ] ] [ -s [ hh:mm:ss ] ] [ -e
[ hh:mm:ss ] ] [ interval [ count ] ]
2)sar简单示例
sar -u 2 5
每隔2秒输出1次CPU统计信息,共输出5次.
sar -I 14 2 10 -o
每隔2秒输出1次关于中断14的统计信息,共输出10次.并把数据信息记录到默认的
/var/log/saXX文件中.
sar -r -n DEV -f /var/log/sa/sa16
显示文件sa16中包含的内存,swap空间和网络的统计信息.
sar -A
显示今天的所有统计信息.
2)sar参数说明
-A 相当于指定了-bBcdqrRuvwWy -I SUM -n FULL -P ALL.
-b 显示I/O和传送速率的统计信息.
tps
每秒到物理磁盘的传送量.1个传送就是1个I/O请求.多个逻辑请求可以被
合并成1个I/O请求.1个传送的大小是不确定的.
rtps
每秒到物理磁盘的读入请求数.
wtps
每秒到物理磁盘的写入请求数.
bread/s
每秒从设备读取的块总数.
bwrtn/s
每秒写入到设备的块总数.
-B
输出页统计信息.
-c 输出进程统计信息.
proc/s 每秒建立的进程总数.
-d 输出每一个块设备的活动信息.
tps
显示每秒到设备的传送数.
rd_sec/s
每秒从磁盘读入的扇区数.
wr_sec/s
每秒向磁盘写入的扇区数.
-e hh:mm:ss
设置输出统计数据的截至时间,默认是18:00:00.
-f filename
从文件读取数据信息.数据信息文件是使用-o选项时生成的文件.
-i interval
指定间隔时长,单位为秒.
-I irq | SUM | ALL | XALL
输出指定中断的统计信息.irq是中断号.SUM指定显示每秒接收到的
中断总数.ALL指定显示前16个中断.XALL指定输出全部的中断信息.
如:
# sar -I 14 1 10
# sar -I SUM 1 5
# sar -I ALL 1 2
-n DEV | EDEV | SOCK | FULL
输出网络统计信息.
-o filename
将信息保存到文件.如: # sar 1 4 -o /var/log/sysstat/sa20
-P cpu | ALL
表示CPU-ID,第一个CPU为0.ALL表示输出所有CPU的统计信息.
-q 输出队列长度和负载状况.
-r 输出内存和swap空间的统计信息.
-R 输出内存统计信息.
-s hh:mm:ss
设置数据统计的起始时间.
-u 输出CPU使用情况的统计信息.
-v 输出inode,文件和其他核心表的信息.
-V 输出版本号和帮助.
-w 输出系统切换信息.
cswch/s
每秒上下文切换的总数.
-W 输出swap统计信息.
-x pid | SELF | ALL
输出指定进程的统计信息.
-X pid | SELF | ALL
输出指定进程的子进程的统计信息.
-y 输出TTY设备的活动信息.