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设备的活动信息.

你可能感兴趣的:(职场,系统,休闲)