IOSTAT

Section: Linux User's Manual (1)
Updated: JULY 2018
Index Return to Main Contents
 

名前

iostat - 中央演算装置 (CPU) の統計と、 デバイスとパーティションの入出力の統計をレポートする。  

書式

iostat [ -c ] [ -d ] [ -h ] [ -k | -m ] [ -N ] [ -s ] [ -t ] [ -V ] [ -x ] [ -y ] [ -z ] [ --dec={ 0 | 1 | 2 } ] [ -j { ID | LABEL | PATH | UUID | ... } ] [ -o JSON ] [ [ -H ] -g group_name ] [ --human ] [ -p [ device [,...] | ALL ] ] [ device [...] | ALL ] [ interval [ count ] ]  

説明

iostat コマンドはシステムの入出力デバイス負荷をモニタリングするのに使う。 負荷として、平均転送レートに関連するデバイスがアクティブな時間を計測する。 iostat は、物理ディスク間の入出力負荷のバランスをよくするための システム設定の変更に使えるレポートを生成する。

iostat が生成する最初のレポートは、 -y オプション (この場合、最初のレポートを省略する) が指定されない限り、 システムがブートしてからの時間に関しての統計を提供する。 それに続くレポートは、その前のレポートからの時間をカバーしている。 iostat が実行されるたびに、すべての統計がレポートされる。 レポートは CPU ヘッダ行に続いて、CPU 統計の行が表示される。 複数プロセッサのシステムでは、CPU 統計はシステム全体のすべての プロセッサの平均が計算される。 デバイスヘッダ行に続いて、設定された各デバイスの統計行が表示される。

interval パラメータは各レポート間の時間を指定する。 count パラメータは interval パラメータと組み合わせて使われる。 count パラメータが指定されると、 countinterval 秒ごとに生成される回数を決定する。 count パラメータを指定せずに interval パラメータを指定すると、 iostat コマンドは連続してレポートを生成する。

 

レポート

iostat は、CPU 利用レポートとデバイス利用レポートの 2 つを生成する。
CPU 利用レポート
iostat コマンドで生成される最初のレポートは、 CPU 利用レポートである。 複数プロセッサのシステムでは、 CPU の値はすべてのプロセッサの全体の平均である。 レポートは以下のフォーマットである。

%user

ユーザレベル (アプリケーション) の実行で発生する CPU 利用の割合。

%nice

nice 優先度が指定されたユーザレベル (アプリケーション) の 実行で発生する CPU 利用の割合。

%system

システムレベル (カーネル) の実行で発生する CPU 利用の割合。

%iowait

システムに目立ったディスク I/O リクエストがあり、 CPU (群) がアイドル状態であった時間の割合。

%steal

ハイパーバイザーが他の仮想プロセッサに サービスを行っているために、 仮想 CPU (群) が不本意に待たされている時間の割合。

%idle

CPU (群) がアイドル状態でシステムに目立った ディスク I/O リクエストがなかった時間の割合。
デバイス利用レポート
iostat コマンドが生成する 2 つ目のレポートは、 デバイス利用レポートである。 デバイスレポートは、物理デバイスまたはパーティションベースの 統計を提供する。 統計を表示するデバイスまたはパーティションは、 コマンドラインから指定できる。 デバイスとパーティションが指定されない場合、 カーネルが統計を保持していて、 かつシステムで使われているすべてのデバイスの統計が表示される。 ALL キーワードがコマンドラインから指定された場合、 使用されていないデバイスを含めて、全てのデバイスの統計が表示される。 環境変数 POSIXLY_CORRECT が指定されない限り、 転送レートは 1K ブロックをデフォルトとして表示される。 環境変数 POSIXLY_CORRECT が指定されると、 512 バイトブロックが使われる。 使用されるフラグに依存して、以下のフィールドがレポートに表示される。

Device:

この列は /dev ディレクトリにリストされている デバイス (またはパーティション) 名を表示する。

tps
1 秒あたりにデバイスに発行された転送回数。 転送はデバイスへの I/O リクエストである。 複数の論理リクエストがデバイスへの 1 つの I/O リクエストにまとめられる場合もある。 転送サイズは不定である。

Blk_read/s (kB_read/s, MB_read/s)
1 秒あたりのデバイスからの読み込みデータのブロック数 (キロバイト数、メガバイト数)。 ブロックはセクターと等価で、サイズは 512 バイトである。

Blk_wrtn/s (kB_wrtn/s, MB_wrtn/s)
1 秒あたりのデバイスへのの書き込みデータのブロック数 (キロバイト数、メガバイト数)。

Blk_read (kB_read, MB_read)
読み込みの総計ブロック数 (キロバイト数、メガバイト数)。

Blk_wrtn (kB_wrtn, MB_wrtn)
書き込みの総計ブロック数 (キロバイト数、メガバイト数)。

r/s
1 秒あたりの (マージ後の) デバイスからの読み込みが完了したリクエスト数。

w/s
1 秒あたりの (マージ後の) デバイスへの書き込みが完了したリクエスト数。

sec/s (kB/s, MB/s)
1 秒あたりのデバイスに対する読み込みと書き出しセクタ数 (キロバイト数、メガバイト数)。

rsec/s (rkB/s, rMB/s)
1 秒あたりのデバイスからの読み込みセクタ数 (キロバイト数、メガバイト数)。

wsec/s (wkB/s, wMB/s)
1 秒あたりのデバイスへの書き出しセクタ数 (キロバイト数、メガバイト数)。

rqm/s
1 秒あたりのデバイスにキューイングされたマージされた I/O リクエスト数。

rrqm/s
1 秒あたりのデバイスにキューイングされたマージされた 読み込みリクエスト数。

wrqm/s
1 秒あたりのデバイスにキューイングされたマージされた 書き込みリクエスト数。

%rrqm
デバイスに送られる前にマージされた読み込みリクエストの割合。

%wrqm
デバイスに送られる前にマージされた書き込みリクエストの割合。

areq-sz
デバイスに発行した I/O リクエストの平均サイズ (キロバイト)。
以前のバージョンでは、このフィールドは avgrq-sz であり、セクタ数を表していた。

rareq-sz
デバイスに発行した読み込みリクエストの平均サイズ (キロバイト)。

wareq-sz
デバイスに発行した書き込みリクエストの平均サイズ (キロバイト)。

await
デバイスに発行した I/O リクエストが処理されるまでの平均時間 (ミリ秒)。 この時間には、リクエストがキューに入っている時間と、 処理される時間が含まれる。

r_await
デバイスに発行した読み込みリクエストが処理されるまでの 平均時間 (ミリ秒)。 この時間には、リクエストがキューに入っている時間と、 処理される時間が含まれる。

w_await
デバイスに発行した書き込みリクエストが処理されるまでの 平均時間 (ミリ秒)。 この時間には、リクエストがキューに入っている時間と、 処理される時間が含まれる。

aqu-sz
デバイスに発行したリクエストの平均のキューの長さ。
以前のバージョンでは、このフィールドは avgqu-sz であった。

svctm
デバイスに発行した I/O リクエストに対する平均サービス時間 (ミリ秒)。 注意!このフィールドを今後信用してはならない。 このフィールドは将来の sysstat バージョンで削除される。

%util
デバイスに I/O リクエストが発行される経過時間の割合 (デバイスのバンド幅使用率)。 リクエストに対してデバイスがシリアルにサービスする場合、 この値が 100% に近いとデバイスの飽和が起こっている。 RAID アレイや最近の SSD のように、リクエストに対して デバイスがパラレルにサービスする場合、 この値は性能限界を反映しない。
 

オプション

-c
CPU 利用レポートを表示する。
-d
デバイス利用レポートを表示する。
--dec={ 0 | 1 | 2 }
使用する小数点の位置を指定する (0 から 2 で、デフォルトは 2 である)。
-g group_name { device [...] | ALL }
デバイスのグループの統計を表示する。 iostat はリストにある各デバイスの統計をレポートしてから、 リストにあるすべてのデバイスを合わせて group_name という名前の統計の行を表示する。 ALL キーワードは、システムに定義されている すべてのブロックデバイスをグループに含めることを意味する。
-H
このオプションは -g オプションと一緒に指定しなければならない。 このオプションを指定すると、グループ全体の統計が表示されるが、 グループの各デバイスの統計は表示されない。
-h
デバイス利用レポートを人間が読みやすいようにする。 このオプションは、 --human を暗黙裡に有効にする。
--human
サイズを人間が読みやすいフォーマット (例えば 1.0k, 1.2M など) で表示する。 このオプションで表示される単位は、指標に紐付けられたデフォルトの単位 (例えば、キロバイト、セクターなど) を上書きする。
-j { ID | LABEL | PATH | UUID | ... } [ device [...] | ALL ]
永続的なデバイス名を表示する。 オプション ID, LABEL などで、永続的なデバイス名のタイプを指定する。 このオプションは限定的ではなく、唯一の必須条件は /dev/disk のディレクトリに永続的なデバイス名が存在することである。 永続デバイス名は通常長いため、 オプションとして、選択した永続名で複数デバイスを指定できる。
-k
1 秒あたりのキロバイトで統計を表示する。
-m
1 秒あたりのメガバイトで統計を表示する。
-N
登録されたデバイスマッパーのデバイスについて、 デバイスマッパー名を表示する。 LVM2 統計を閲覧するのに役立つ。
-o JSON
統計を JSON (Javascript Object Notation) 形式で表示する。 JSON 出力のフィールド順は定義されておらず、 将来新しいフィールドが追加されるかもしれない。
-p [ { device [,...] | ALL } ]
-p オプションはシステムで使われているブロックデバイスと すべてのパーティションの統計を表示する。 デバイス名がコマンドラインで指定された場合、 そのデバイスとすべてのパーティションが表示される。 ALL キーワードは、使用されていないブロックデバイスを含む、 システムで定義されているすべてのブロックデバイスと パーティションの統計を表示する。 このオプションより前に、オプション -j が定義されていると、コマンドラインで入力されるデバイスは、 選択された永続名タイプで指定できる。
-s
80 文字幅の画面に合うように、短い (狭い) バージョンのレポートを表示する。
-t
各レポートで時間を表示する。 タイムスタンプの形式は、S_TIME_FORMAT 環境変数の値に依存する (下記を参照)。
-V
バージョン番号を表示して、終了する。
-x
拡張された統計を表示する。
-y
指定された間隔で複数レコードを表示する場合、 システムブートからの統計の最初のレポートを省略する。
-z
iostat に対して、サンプリング期間に活動がないデバイスを出力から省略させる。

 

環境変数

iostat コマンドは以下の環境変数を扱う。

POSIXLY_CORRECT
この環境変数が設定されると、転送レートが 1K ブロックではなく、 512 バイトブロックで表示される。

S_COLORS
この環境変数を設定すると、端末上で統計をカラー表示する。 この環境変数に指定可能な値は、 never, always, auto である (最後がデフォルトである)。

値を表示する色 (赤、黄、またはその他の色) は、色によって何かの意味を示している訳ではない。 色は値の範囲を示しているだけである。

S_COLORS_SGR
端末で統計を表示する際に、色とその他の属性を指定する。 この値は、コロン区切りの機能のリストで、デフォルトは H=31;1:I=32;22:M=35;1:N=34;1:Z=34;22 である。 サポートされている機能は以下のとおり。

H=
割合が 75% 以上の場合の SGR (Select Graphic Rendition) 部分文字列。

I=
デバイス名を表示する SGR 部分文字列。

M=
割合が 50% から 75% の場合の SGR 部分文字列。

N=
0 以外の統計値を表示する SGR 部分文字列。

Z=
0 を表示する SGR 部分文字列。

S_TIME_FORMAT
この環境変数が存在し、かつ値が ISO の場合、レポートのヘッダの日付を表示する際に、 現在のロケールを無視する。 代わりに、 iostat コマンドは ISO 8601 フォーマット (YYYY-MM-DD) を使う。 -t オプションのタイムスタンプも ISO 8601 フォーマットに従う。

 

iostat
すべての CPU とデバイスのブート時からの 1 回分の履歴を表示する。

iostat -d 2
デバイスのレポートを 2 秒間隔で連続して表示する。

iostat -d 2 6
すべてのデバイスのレポートを 2 秒間隔で 6 回表示する。

iostat -x sda sdb 2 6
デバイス sda と sdb の拡張した統計を 2 秒間隔で 6 回表示する。

iostat -p sda 2 6
デバイス sda と、そのすべてのパーティション (sda1 など) のレポートを 2 秒間隔で 6 回表示する。
 

バグ

iostat コマンドが動作するためには、 /proc ファイルシステムがマウントされていなければならない。

2.6.x より古いカーネルは、もはやサポートしていない。

平均サービス時間 (svctm フィールド) は意味がない。 現状、I/O 統計はブロックレベルで計算されており、 ディスクドライバーがいつリクエストを処理するかは、 分からないためである。 そのため、このフィールドは将来の sysstat のバージョンで削除される。  

ファイル

/proc/stat システム統計を保持する。

/proc/uptime システム uptime を保持する。

/proc/diskstats ディスク統計を保持する。

/sys ブロックデバイス統計を保持する。

/proc/self/mountstats ネットワークファイルシステム統計を保持する。

/dev/disk 永続デバイス名を保持する。  

著者

Sebastien Godard (sysstat <at> orange.fr)  

関連項目

sar(1), pidstat(1), mpstat(1), vmstat(8), tapestat(1), nfsiostat(1), cifsiostat(1)

https://github.com/sysstat/sysstat

http://pagesperso-orange.fr/sebastien.godard/


 

Index

名前
書式
説明
レポート
オプション
環境変数
バグ
ファイル
著者
関連項目

This document was created by man2html, using the manual pages.
Time: 06:50:54 GMT, July 13, 2019