天天看点

【AIX 学习】性能优化--iostat (续)

tty 和 cpu 使用率报告

由 iostat 命令生成的第一份报告是 tty 和 cpu 使用率报告。对于多处理器系统,cpu 值是所有处理器的总平均。同时,i/o 等待状态是系统级定义的,而不是每个处理器。报告有以下格式:

栏 描述

tin 显示了系统为所有 tty 读取的字符总数。

tout 显示了系统为所有 tty 写入的字符总数。

% user 显示了在用户级(应用程序)执行时生成的 cpu 使用率百分比。

% sys 显示了在系统级(内核)执行时生成的 cpu 使用率百分比。

% idle 显示了在 cpu 空闲并且系统没有未完成的磁盘 i/o 请求时的时间百分比。

% iowait 显示了 cpu 空闲期间系统有未完成的磁盘 i/o 请求时的时间百分比。

physc 消耗的物理处理器的数量,仅当分区与共享处理器运行时显示。

% entc 消耗的标题容量的百分比,仅当分区与共享处理器运行时显示。由于计算该数据所依据的时间基础会发生变化,因此授权容量百分比有时可能超过 100%。这种超过只在采样时间间隔很小时才会比较明显。

每过一定时间间隔,内核就更新这条信息(一般每秒六十次)。tty 报告提供了从系统中所有终端的收到的每秒字符总数,以及和每秒输出到系统所有终端的字符的总数。

用来计算 cpu 磁盘 i/o 等待时间的方法

操作系统 v4.3.3 和后来的版本包含用来估算 cpu 在磁盘 i/o(wio 时间)等待上的所花时间的百分比的增强方法。用在 aix 4.3.2 和操作系统的早期版本上的方法在一定条件下,能够给出 smp 上的 wio 时间的一个放大的视图。wio 时间是根据命令 sar(%wio)、vmstat(wa)和 iostat(% iowait)报告出来的。

在 aix 4.3.2 中和早期版本中使用的方法如下:在每个处理器(每处理器一秒一百次)的每个时钟中断上,将确定四个类别(usr/sys/wio/idle)中的哪一个放置在最后的 10ms 内。如果在时钟中断的时刻 cpu 以 usr 模式中处于忙状态,则 usr 获得这个时间计点并归于此类。如果在时钟中断时刻 cpu 以内核模式中处于忙状态,则 sys 类别将获得该计时点。如果 cpu 不处于忙状态,将检查是否在进行任何磁盘 i/o。如果在进行任何磁盘 i/o,则 wio 类别将增加。如果磁盘在进行 i/o 操作并且 cpu 不忙,则 idle 类别将获取计时点。wio 时间的放大视图是由于所有空闲 cpu 被归为 wio 而不管在 i/o 上等待的线程数所导致。例如,仅有一个线程执行 i/o 的系统可以报告超过 90% 的 wio 时间而不管其 cpu 数。

在 aix 4.3.3 中和后继版本中使用的方法如下:如果在那个 cpu 上启动一个未完成的 i/o,则操作系统 v4.3.3 中的更改仅将一个空闲 cpu 标为 wio。当只有少数线程正在执行 i/o 否则系统就空闲的情况下,这种方法可以报告更少的 wio 时间。例如,一个有四个 cpu 且只有一个线程执行 i/o 的系统将报告一个最大值是 25% 的 wio 时间。一个有 12 个 cpu 且仅有一个线程执行 i/o 的系统将报告一个最大值为 8% 的 wio 时间。 nfs 客户机通过 vmm 读/写,并且为了完成一个 i/o 而在 vmm 等待中用的时间现在将被报告为 i/o 等待时间。

磁盘使用率报告

由 iostat 命令生成的第二个报告是磁盘使用率报告。磁盘报告提供了在每个物理磁盘基础上的统计信息。缺省报告有与以下类似的格式:

% tm_act 表示物理磁盘处于活动状态的时间百分比(驱动器的带宽使用率)。

kbps 表示以 kb 每秒为单位的传输(读或写)到驱动器的数据量。

tps 表示每秒钟输出到物理磁盘的传输次数。一次传输就是一个对物理磁盘的 i/o 请求。多个逻辑请求可被并为对磁盘的一个单一 i/o 请求。传输具有不确定的大小。

kb_read 读取的 kb 总数。

kb_wrtn 写入的 kb 总数。

如果指定了 -d 标志,则报告有以下度量值:

与磁盘传送(xfer)有关的度量值: 

bps 表示每秒传输(读或写)到驱动器的数据量。使用不同的后缀来代表传送单位。缺省单位是字节/秒。

bread 表示每秒从驱动器上读取的数据量。使用不同的后缀来代表传送单位。缺省单位是字节/秒。

bwrtn 表示每秒写入到驱动器的数据量。使用不同的后缀来代表传送单位。缺省单位是字节/秒。

磁盘读取服务度量值(读取): 

rps 表示每秒读取传输的数量。

avgserv 表示每次读取传输的平均服务时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

minserv 表示最少的读取服务时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

maxserv 表示最多的读取服务时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

timeouts 表示每秒读取超时的数量。

fails 表示每秒失败的读取请求的数量。

磁盘写入服务度量值(写入): 

wps 表示每秒写入传输的数量。

avgserv 表示每次写入传输的平均服务时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

minserv 表示最少的写入服务时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

maxserv 表示最多的写入服务时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

timeouts 表示每秒写入超时的数量。

fails 表示每秒失败的写入请求的数量。

磁盘等待队列服务度量值(队列): 

avgtime 表示传输请求在等待队列中所花的平均时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

mintime 表示传输请求在等待队列中所花的最短时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

maxtime 表示传输请求在等待队列中所花的最长时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

avgwqsz 表示等待队列的平均大小。

avgsqsz 表示服务队列的平均大小。

sqfull 表示每秒内服务队列变满(即,磁盘不再接受任何服务请求)的次数。

代表不同说明单元的后缀图注

后缀 描述

k 1000 字节

m 1 000 000 字节(如果以 xfer 度量值显示)。分钟(如果以读取/写入/等待服务度量值显示)。

g 1 000 000 000 字节。

t 1 000 000 000 000 字节。

s 秒。

h 小时。

注:

对于不支持服务时间度量值的驱动器,将不显示读取、写入和等候队列服务度量值。

cd-rom 设备的统计信息也要报告。

系统吞吐量报告

如果指定 -s 标志将生成这个报告。这份报告提供了整个系统的统计信息。这份报告有以下格式:

kbps 表示了每秒以 kb 为单位的传输(读或写)到整个系统的数据量。

tps 表示每秒传输到整个系统的传输次数。

kb_read 从整个系统中读取的 kb 总数。

kb_wrtn 写到整个系统的 kb 总数。

适配器吞吐量报告

如果指定 -a 标志将生成该报告。这份报告提供了以每个适配器(包括物理适配器和虚拟适配器)为基础的统计信息。该报告对于物理适配器报告具有以下格式:

kbps 表示每秒钟以 kb 为单位的传输到(读或写)到适配器的数据量。

tps 表示每秒钟输出到适配器的传输次数。

kb_read 从适配器读取的 kb 总数。

kb_wrtn 写到适配器的 kb 总数。

虚拟适配器的缺省吞吐量报告有以下格式:

bkread 每秒从托管服务器接收至该适配器的块数。

bkwrtn 每秒从该适配器发送至托管服务器的块数。

partition-id 托管服务器的分区标识,它为该适配器发送的请求提供服务。

虚拟适配器的扩展吞吐量报告(-d 选项)有以下格式:

与传送(xfer:)有关的度量值 

适配器读取服务度量值(读取:) 

rps 表示每秒读取请求的数量。

avgserv 表示为已发送的读取请求从托管服务器上接收响应的平均时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

minserv 表示为已发送的读取请求从托管服务器上接收响应的最短时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

maxserv 表示为已发送的读取请求从托管服务器上接收响应的最长时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

适配器写入服务度量值(写入:) 

wps 表示每秒写入请求的数量。

avgserv 表示为已发送的写入请求从托管服务器上接收响应的平均时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

minserv 表示为已发送的写入请求从托管服务器上接收响应的最短时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

maxserv 表示为已发送的写入请求从托管服务器上接收响应的最长时间。使用不同的后缀来代表时间单位。缺省单位是毫秒。

适配器等待队列度量值(队列:) 

sqfull 表示每秒内服务队列变满(即,托管服务器不再接受任何服务请求)的次数。

k 1000 字节。

异步 i/o 报告

异步 i/o 报告有以下列标题:

avgc 指定时间间隔的每秒平均全局 aio 请求计数。

avfc 指定时间间隔的每秒平均快速路径请求计数。

maxgc 上一次访存这个值以来的最大全局 aio 请求计数。

maxfc 上一次访存这个值以来的最大快速路径请求计数。

maxreqs 所允许的最大 aio 请求数。

磁盘输入/输出历史记录

为了提高性能,已经禁用了磁盘输入/输出统计信息的收集。要启用该数据的集合,请输入:

chdev -l sys0 -a iostat=true

要显示当前设置,请输入:

lsattr -e -l sys0 -a iostat

如果禁用了磁盘输入/输出历史记录的收集,并且在不带时间间隔的情况下调用了 iostat,则 iostat 输出将显示消息自引导以来的磁盘历史记录不可用,而不是磁盘统计信息。

标志

-a 指定适配器吞吐量报告。

-a 显示指定时间间隔和计数的 aio 统计信息。

-d 只指定驱动器报告。

-d 只指定扩展驱动器报告。

-l 对长列表方式显示输出。缺省列宽是 80。

-m 指定路径的统计信息。

-p 与 -a 选项相同,使用 posix aio 调用获取的数据除外。

-q 指定 aio 队列和它们的请求计数。

-q 显示所有安装的文件系统和相关的队列数以及它们请求计数的列表。

-r 指定在每个时间间隔都应复位 min* 和 max* 值。缺省情况下将仅在 iostat 启动时执行一次复位。

-s 指定系统吞吐量报告。

-t 只指定 tty/cpu 报告。

-t 指定时间戳记。

-z 复位磁盘输入/输出统计信息。只有 root 用户才可以使用此选项。

-q 或 -q 只能与 -a 一起指定。

-a 和 -s 也可以与 -a 一起指定,但在指定了-q 或 -q 时不能与 -a 一起指定。

-t 和 -d 不能同时指定。

-d 和 -d 不能同时指定。

-r 只能和 -d 一起指定。

示例

要为所有 tty、cpu 和磁盘显示引导后的单一历史记录报告,请输入:

iostat

要为逻辑名是 disk1 的磁盘显示一个以两秒为时间间隔的持续磁盘报告,请输入:

iostat -d disk1 2

要为逻辑名是 disk1 的磁盘显示以两秒为时间间隔的六个报告,请输入:

iostat disk1 2 6

要为所有磁盘显示以两秒为时间间隔的六个报告,请输入:

iostat -d 2 6

要为三个名称分别为 disk1、disk2、disk3 的磁盘显示以两秒为时间间隔的六个报告,请输入:

iostat disk1 disk2 disk3 2 6

要打印系统引导以来的系统吞吐量报告,请输入:

iostat -s

要打印以五秒为时间间隔的适配器吞吐量报告,请输入:

iostat -a 5

要打印以二十秒为时间间隔的十个系统和适配器吞吐量报告,且仅带有 tty 和 cpu 报告(没有磁盘报告),请输入:

iostat -sat 20 10

要打印带有 hdisk0 和 hdisk7 的磁盘使用率报告的系统和适配器吞吐量报告(每 30 秒一次),请输入:

iostat -sad hdisk0 hdisk7 30

要显示 iostat 输出的每行的下一行的时间戳记,请输入:

iostat -t 60

要显示关于 aio 的以两秒为时间间隔的六个报告,请输入:

iostat -a 2 6

要显示自引导以来与所有已安装的文件系统相关的队列的 aio 统计信息,请输入:

iostat -a -q

要显示所有磁盘的扩展驱动器报告,请输入:

iostat -d

要显示某个特定磁盘的扩展驱动器报告,请输入:

iostat –d hdisk0

要复位磁盘输入/输出统计信息,请输入:

iostat –z