Linux系统整体性能监控工具详解(下)

发表于:2007-05-26来源:作者:点击数: 标签:
6. iostat iostat [-t] [-c] [interval [count]] 参数的含义如下: 参数 解释 T 表示输出采用的时间 C 表示只显示CPU的信息 Internal 相邻的两次采样的间隔时间 count 采样的次数,count只能和delay一起使用 当没有参数时,iostat则显示系统启动以后所有信息

6. iostat

iostat [-t] [-c] [interval [count]]

参数的含义如下:

参数 解释

T 表示输出采用的时间

C 表示只显示CPU的信息

Internal 相邻的两次采样的间隔时间

count 采样的次数,count只能和delay一起使用

当没有参数时,iostat则显示系统启动以后所有信息的平均值。

与CPU有关的输出的含义

参数 解释 从/proc/stat获得

CPU 处理器ID

user 在internal时间段里,用户态的CPU时间(%) ,不包含 nice值为负进程 usr/total*100

nice 在internal时间段里,nice值为负进程的CPU时间(%) nice/total*100

sys 在internal时间段里,核心时间(%) (system+irq+softirq)/total*100

iowait 在internal时间段里,硬盘IO等待时间(%) iowait/total*100

idle 在internal时间段里,CPU除去等待磁盘IO操作外的因为任何原因而空闲的时间闲置时间 (%) idle/total*100

CODE:

 

total_cur=user+system+nice+idle+iowait+irq+softirq
            total_pre=pre_user+ pre_system+ pre_nice+ pre_idle+ pre_iowait+ pre_irq+ pre_softirq
            total=total_cur-total_pre

有interval时,第一行的信息自系统启动以来的平均信息。从第二行开始,输出为前一个interval时间段的平均信息。

范例1:

CODE:

 

[root@localhost /]# dd if=/dev/zero of=/1.img bs=1024 count=1000000&
            [1] 15854
            [root@localhost /]# iostat -c 1
            Linux 2.6.13 (localhost.localdomain) 2005年12月19日
            avg-cpu: %user %nice %sys %iowait %idle
            1.94 0.00 0.56 0.75 96.75
            avg-cpu: %user %nice %sys %iowait %idle
            3.65 0.00 13.87 82.48 0.00
            avg-cpu: %user %nice %sys %iowait %idle

7. sar

sar是System Activity Reporter(系统活跃情况报告)的缩写。顾名思义,sar工具将对系统当前的状态进行采样,然后通过计算数据和比例来表达系统的当前运行状态。它的特点是可以连续对系统采样,获得大量的采样数据;采样数据和分析的结果都可以存入文件,所需的负载很小。这些是检查历史数据和一些近来的系统事件。sar用于检查的性能数据类似于vmstat, mpstat和 iostat的显示。 sar的数据是一段时间保存的内容,因此可以察看过去的信息。 lastcomm可以现在系统最近被执行的命令。这些可以用在系统审计中。sa 可以在*BSD和Linux中找到,它给用户在系统审计中更多的选项来收集信息。

在反馈CPU整体信息方面,sar 反馈的与CPU相关的信息包括:

(1)多少任务在运行

(2)CPU使用的情况

(3)CPU收到多少中断

(4)发生多少上下文切换

sar的语法如下:

sar [-options] [interval [count]]

其中,internal是两次采样的间隔时间;count是指采样的次数;与CPU相关的options有:

参数的含义如下:

参数 解释

-c 表示输出采用的时间

-e hh:mm:ss 表示只显示CPU的信息

-i {irq |SUM|ALL|XALL} 相邻的两次采样的间隔时间

-P {cpu|ALL}

-q 显示在采样的时刻,可运行队列的任务的个数,以及系统平均负载

-u CPU 使用的情况,报告了cpu的用户态,系统态,等待I/O和空闲时间上的百分比。

-w:每秒上下文交换率

-o:filename 将结果放在文件里

-f:filename 表示从file文件中取出数据,如果没有指定-f file,则从标准数据文件

范例1:

首先在后台运行一个创建1GB文件的任务,然后输入:“sar -c -q -w 3 2”,表示每3秒采样一次,采样两次,可以看到系统有82个任务,但是在10时12分08秒时有一个任务在运行,在下一次采样10时12分11秒时,没有任务在运行。

CODE:

 

[root@localhost /]# dd if=/dev/zero of=/1.img bs=1024 count=1000000&
            [1] 16213
            [root@localhost /]# sar -c -q -w -I SUM 3 2
            Linux 2.6.13 (localhost.localdomain) 2005年12月19日
            10时12分05秒 proc/s
            10时12分08秒 0.00
            10时12分05秒 cswch/s
            10时12分08秒 692.33
            10时12分05秒 INTR intr/s
            10时12分08秒 sum 895.33
            10时12分05秒 runq-sz plist-sz ldavg-1 ldavg-5 ldavg-15
            10时12分08秒 1 82 0.20 0.08 0.09
            10时12分08秒 proc/s
            10时12分11秒 0.00
            10时12分08秒 cswch/s
            10时12分11秒 648.50
            10时12分08秒 INTR intr/s
            10时12分11秒 sum 461.79
            10时12分08秒 runq-sz plist-sz ldavg-1 ldavg-5 ldavg-15
            10时12分11秒 0 82 0.59 0.16 0.12
            Average: proc/s
            Average: 0.00
            Average: cswch/s
            Average: 670.38
            Average: INTR intr/s
            Average: sum 678.20
            Average: runq-sz plist-sz ldavg-1 ldavg-5 ldavg-15
            Average: 0 82 0.40 0.12 0.10

与CPU有关的输出的含义

参数 解释 从/proc/stat获得数据

proc/s 在internal时间段里,每秒上下文切换率 processes/total*100

cswch 在internal时间段里,每秒上下文切换率 ctxt/total*100

intr/s 在internal时间段里,每秒CPU接收的中断的次数 idle/total*100

从/proc/loadavg获得数据

runq-sz 采样时,运行队列中任务的个数,不包括vmstat 进程。 procs_running-1

plist-sz 采样时,系统中活跃的任务的个数 nr_threads

ldavg-1 采样的前一秒钟系统的负载(%) lavg_1

ldavg-5 采样的5秒钟系统的负载(%) lavg_5

ldavg-15 采样的前15秒钟系统的负载(%) lavg_15

下面输入命令“sar 3 2”,表示每隔3秒显示CPU的状态,共显示2次。此时创建1GB文件的任务还在后台进行。

CODE:

 

[root@localhost /]# sar 3 2
            Linux 2.6.13 (localhost.localdomain) 2005年12月19日
            10时12分37秒 CPU %user %nice %system %iowait %idle
            10时12分40秒 all 2.91 0.00 14.18 82.91 0.00
            10时12分43秒 all 2.66 0.00 14.95 82.39 0.00
            Average: all 2.78 0.00 14.58 82.64 0.00
            [root@localhost /]#

与CPU有关的输出的含义

参数 解释 从/proc/stat获得数据

CPU 处理器ID

user 在internal时间段里,用户态的CPU时间(%) ,不包含 nice值为负进程 usr/total*100

nice 在internal时间段里,nice值为负进程的CPU时间(%) nice/total*100

sys 在internal时间段里,核心时间(%) (system+irq+softirq)/total*100

iowait 在internal时间段里,硬盘IO等待时间(%) iowait/total*100

idle 在internal时间段里,CPU除去等待磁盘IO操作外的因为任何原因而空闲的时间闲置时间 (%) irq/total*100

输入命令“sar”,当不带任何参数时,表示每一秒采样一次,每次显示从系统到该采样时系统的平均信息。从Fig.8看出在10时12分43秒,系统idle应该为0,而Fig.9

CODE:

 

[root@localhost /]# sar
            Linux 2.6.13 (localhost.localdomain) 2005年12月19日
            00时00分01秒 CPU %user %nice %system %iowait %idle
            00时10分01秒 all 0.11 0.00 0.16 0.00 99.73
            00时20分01秒 all 0.13 0.00 0.15 0.00 99.72
            .
            .
            .
            08时10分01秒 all 0.11 0.00 0.14 0.00 99.75
            08时20分01秒 all 0.13 0.00 0.15 0.00 99.72
            08时30分01秒 all 0.13 0.00 0.16 0.00 99.71
            08时40分01秒 all 3.96 0.00 0.57 0.34 95.12
            08时50分01秒 all 7.42 0.00 0.77 0.74 91.07
            09时00分01秒 all 4.93 0.00 1.97 8.14 84.95
            09时10分01秒 all 4.81 0.00 0.69 0.29 94.21
            09时20分01秒 all 3.09 0.00 0.93 1.72 94.25
            09时30分01秒 all 7.59 0.00 1.59 1.27 89.55
            09时40分01秒 all 2.27 0.00 0.74 0.32 96.67
            09时50分01秒 all 4.81 0.00 0.81 0.07 94.31
            10时00分02秒 all 1.84 0.00 2.17 7.78 88.21
            10时10分01秒 all 0.63 0.00 0.24 0.20 98.93
            10时20分02秒 all 1.70 0.00 1.85 7.95 88.50
            10时30分01秒 all 0.50 0.00 0.21 0.21 99.08
            Average: all 0.81 0.00 0.33 0.49 98.37
            [root@localhost /]#
            total_cur=user+system+nice+idle+iowait+irq+softirq
            total_pre=pre_user+ pre_system+ pre_nice+ pre_idle+ pre_iowait+ pre_irq+ pre_softirq
            total=total_cur-total_pre

上表中的所有值可取到两位小数点。

范例2:

CODE:

 

[work@builder linux-2.6.14]$ sar –P ALL 2 3
            Linux 2.6.9-5.31AXsmp (builder.redflag-linux.com) 12/28/2005
            08:28:45 AM CPU %user %nice %system %iowait %idle
            08:28:47 AM all 0.00 0.00 0.00 0.00 100.00
            08:28:47 AM 0 0.00 0.00 0.00 0.00 100.00
            08:28:47 AM 1 0.00 0.00 0.00 0.00 100.00
            08:28:47 AM 2 0.00 0.00 0.00 0.00 100.00
            08:28:47 AM 3 0.00 0.00 0.00 0.00 100.00
            08:28:47 AM CPU %user %nice %system %iowait %idle
            08:28:49 AM all 0.00 0.00 0.00 0.00 100.00
            08:28:49 AM 0 0.00 0.00 0.00 0.00 100.00
            08:28:49 AM 1 0.00 0.00 0.00 0.00 100.00
            08:28:49 AM 2 0.00 0.00 0.00 0.00 100.00
            08:28:49 AM 3 0.00 0.00 0.00 0.00 100.00
            08:28:49 AM CPU %user %nice %system %iowait %idle
            08:28:51 AM all 0.00 0.00 0.12 0.25 99.63
            08:28:51 AM 0 0.00 0.00 0.00 0.00 100.00
            08:28:51 AM 1 0.00 0.00 0.00 0.50 99.50
            08:28:51 AM 2 0.00 0.00 0.00 0.00 100.00
            08:28:51 AM 3 0.00 0.00 0.00 0.00 100.00
            Average: CPU %user %nice %system %iowait %idle
            Average: all 0.00 0.00 0.04 0.08 99.88
            Average: 0 0.00 0.00 0.00 0.00 100.00
            Average: 1 0.00 0.00 0.00 0.17 99.83
            Average: 2 0.00 0.00 0.00 0.00 100.00
            Average: 3 0.00 0.00 0.00 0.00 100.00
            Fig.1.

8. top

top命令提供了实时的对系统处理器的状态监视,即可以通过用户按键来不断刷新当前状态。如果前台执行该命令,它将独占前台,直到用户终止该程序为止,但是该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定。

下面是该命令的语法格式:

top [-] [d delay] [options]

一些参数的含义如下:

参数 解释

d delay 相邻的两次采样的间隔时间

q 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行

-l 不显示空闲进程,默认时,top显示空闲进程

-S 将系统进程信息也显示于屏幕,默认时,不显示。

与cPU有关的输出的含义

参数 解释

CPU信息 从/proc/stat获得信息

us 在internal时间段里,用户态的CPU时间(%),不包含nice值为负的任务占用的CPU的时间

usr/total*100

ni 在internal时间段里,nice值为负的任务的用户态的Niced进程的CPU时间(%) nice/total*100

sy 在internal时间段里,核心态的CPU时间(%) system/total*100

id 在internal时间段里,cpu空闲的时间,不包括等待i/o的时间(%) idle/total*100

wa 在internal时间段里,等待i/o的时间(%) iowait/total*100

hi 在internal时间段里,硬中断时间(%) irq/total*100

si 在internal时间段里,软中断时间(%) softirq/total*100

任务

total 采样时,系统全部进程的个数,包括正在运行的top进程,不包括线程。 =running+sleeping+stopped+zombie

running 采样时,运行队列的进程的个数,但不包含top这个进程 通过判断/proc/pid/status中stat的值。

sleeping 采样时,可中断和不可中断状态的进程的个数

stopped 采样时,停止状态的进程的个数

zombie 采样时,僵尸状态的进程的个数

运行中的参数的含义

参数 解释

q 退出程序

r 重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID

S 切换到累计模式

L 切换显示平均负载和启动时间信息

T 切换显示进程和CPU状态信息

M 切换显示内存信息

s 改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加 

范例1:查看 键入top命令查看系统状况

CODE:

 

>top
            top - 16:52:17 up 3 min, 1 user, load average: 0.10, 0.27, 0.14
            Tasks: 55 total, 1 running, 54 sleeping, 0 stopped, 0 zombie
            top - 16:52:31 up 4 min, 1 user, load average: 0.08, 0.26, 0.13
            Tasks: 55 total, 1 running, 54 sleeping, 0 stopped, 0 zombie
            Cpu(s): 0.3% us, 0.3% sy, 0.0% ni, 99.0% id, 0.0% wa, 0.3% hi, 0.0% si
            Mem: 251924k total, 238168k used, 13756k free, 4420k buffers
            Swap: 0k total, 0k used, 0k free, 165200k cached
            PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
            4171 root 15 0 48404 12m 2220 S 0.7 5.0 0:01.36 X
            4404 root 15 0 66540 16m 13m S 0.3 6.9 0:02.31 kdeinit
            1 root 16 0 1772 544 464 S 0.0 0.2 0:00.61 init
            2 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0
            3 root 5 -10 0 0 0 S 0.0 0.0 0:00.00 events/0
            4 root 5 -10 0 0 0 S 0.0 0.0 0:00.02 khelper
            5 root 15 -10 0 0 0 S 0.0 0.0 0:00.00 kacpid
            19 root 5 -10 0 0 0 S 0.0 0.0 0:00.00 kblockd/0
            29 root 20 0 0 0 0 S 0.0 0.0 0:00.00 pdflush
            30 root 15 0 0 0 0 S 0.0 0.0 0:00.01 pdflush
            32 root 14 -10 0 0 0 S 0.0 0.0 0:00.00 aio/0
            20 root 15 0 0 0 0 S 0.0 0.0 0:00.00 khubd
            31 root 15 0 0 0 0 S 0.0 0.0 0:00.01 kswapd0
            618 root 25 0 0 0 0 S 0.0 0.0 0:00.00 kseriod

第一行的项目依次为当前时间、系统启动时间、当前系统登录用户数目、平均负载。

第二行为进程情况,依次为进程总数、休眠进程数、运行进程数、僵死进程数、终止进程数。

第三行为CPU状态,依次为用户占用、系统占用、优先任务占用、闲置任务占用。

第四行为内存状态,依次为平均可用内存、已用内存、空闲内存、共享内存、缓存使用内存。

第五行为交换状态,依次为平均可用交换容量、已用容量、闲置容量、交换高速缓存容量。

然后下面就是和ps相仿的各进程情况列表了。

总的来说,top命令的功能强于ps,但需要长久占用前台,所以用户应该根据自己的情况来使用这个命令。

9. oprofile

Oprofile这个性能监视工具是利用处理器上所包含的专用的性能监视硬件(若没有性能监视硬件则使用一个基于计时器的代用品)来收集与性能相关的数据样品(samples)。它获得关于内核以及系统上的可执行文件的信息,例如内存是何时被引用的;L2缓存请求的数量;收到的硬件中断数量等。

下表提供了对 oprofile 软件包中包括的工具的总览。

命令 描述

opcontrol 配置要收集的数据

op_help 显示系统处理器的可用事件以及每个事件的简单描述

opreport 获得有用的profile数据

Opannotate 如果应用程序使用调试符号编译了,创建带注解

oprofiled 作为守护进程来运行,定期把样品数据写入磁盘

Oparchive 收集可执行文件信息和调试信息,将采样文件归档

op_import 把样品数据库文件从异类二进制格式转换成系统的本地原始格式。只有在分析不同体系的样品数据库时才使用该选项。

(1)opcontrol

在运行 OProfile 之前,必须用opcontrol配置监视环境。在 opcontrol 命令被执行时,设置选项就会被保存到 /root/.oprofile/daemonrc 文件中。

命令格式

opcontrol [--vmlinux] [--start] [--stop] [--dump] [--shutdown] [--save=filename]

参数解释

参数 描述

vmlinux 用来配置是否监视内核。要监视内核,以根用户身份执行以下命令:

>opcontrol --vmlinux=/usr/src/linux-2.6.13/vmlinux

要配置 OProfile 不监视内核,以根用户身份执行以下命令:

>opcontrol --no-vmlinux

这个命令还会载入 oprofile 内核模块(如果还没有被载入),并创建 /dev/oprofile/ 目录(如果不存在)。

start 开始监视系统

要使用 OProfile 来开始监视系统,以根用户身份执行以下命令:

CODE:

 

>opcontrol --start
            Reading module info.
            Using log file /var/lib/oprofile/oprofiled.log
            Daemon started.
            Profiler running.

/root/.oprofile/daemonrc 中的设置被使用。OProfile 守护进程 oprofiled 被启动;它定期把样品数据写入 /var/lib/oprofile/samples/ 目录。该守护进程的日志位于 /var/lib/oprofile/oprofiled.log。如果 OProfile 使用不同的配置选项被重新启动,以前会话中的样品文件就会被自动备份到 /var/lib/oprofile/samples/session-N 目录中,这里的 N 是前一次备份会话数量再加1。

stop 停止监视

Shutdown 要停止建档器,以根用户身份执行以下命令:

>opcontrol –shutdown

Save save 保存数据

要保存当前的抽样文件集合,执行以下命令,把 替换成当前会话中的独特描述性名称。 opcontrol --save= 目录 /var/lib/oprofile/samples/name/ 被创建,当前的抽样文件被复制到其中。

Dump dump OProfile 守护进程 oprofiled 定期收集样品,并把它们写入 /var/lib/oprofile/samples/ 目录。在读取数据之前,请以根用户身份执行以下命令来确定所有数据都被写入这个目录中了。

原文转自:http://www.ltesting.net