sysstat工具包

 

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

你可能感兴趣的:(linux,职场,休闲,sysstat)