iostat命令詳解

Linux系統中的 iostat是I/O statistics(輸入/輸出統計)的縮寫,iostat工具將對系統的磁盤操做活動進行監視。它的特色是彙報磁盤活動統計狀況,同時也會彙報出CPU使用狀況。同vmstat同樣,iostat也有一個弱點,就是它不能對某個進程進行深刻分析,僅對系統的總體狀況進行分析。iostat屬於sysstat軟件包。能夠用yum install sysstat 直接安裝。ios

1.命令格式:

iostat[參數][時間][次數]shell

2.命令功能:

  經過iostat方便查看CPU、網卡、tty設備、磁盤、CD-ROM 等等設備的活動狀況, 負載信息express

3.命令參數:

-C 顯示CPU使用狀況工具

-d 顯示磁盤使用狀況優化

-k 以 KB 爲單位顯示spa

-m 以 M 爲單位顯示code

-N 顯示磁盤陣列(LVM) 信息orm

-n 顯示NFS 使用狀況隊列

-p[磁盤] 顯示磁盤和分區的狀況進程

-t 顯示終端和CPU的信息

-x 顯示詳細信息

-V 顯示版本信息

4.使用實例:

實例1:顯示全部設備負載狀況

命令:

iostat

輸出:

[root@CT1186 ~]#iostat
Linux 2.6.18-128.el5 (CT1186)   2012年12月28日
avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           8.30    0.02    5.07    0.17    0.00   86.44
Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda              22.73        43.70       487.42  674035705 7517941952
sda1              0.00         0.00         0.00       2658        536
sda2              0.11         3.74         3.51   57721595   54202216
sda3              0.98         0.61        17.51    9454172  270023368
sda4              0.00         0.00         0.00          6          0
sda5              6.95         0.12       108.73    1924834 1677123536
sda6              2.20         0.18        31.22    2837260  481488056
sda7             12.48        39.04       326.45  602094508 5035104240

說明:

cpu屬性值說明:

%user:CPU處在用戶模式下的時間百分比。

%nice:CPU處在帶NICE值的用戶模式下的時間百分比。

%system:CPU處在系統模式下的時間百分比。

%iowait:CPU等待輸入輸出完成時間的百分比。

%steal:管理程序維護另外一個虛擬處理器時,虛擬CPU的無心識等待時間百分比。

%idle:CPU空閒時間百分比。

備註:若是%iowait的值太高,表示硬盤存在I/O瓶頸,%idle值高,表示CPU較空閒,若是%idle值高但系統響應慢時,有多是CPU等待分配內存,此時應加大內存容量。%idle值若是持續低於10,那麼系統的CPU處理能力相對較低,代表系統中最須要解決的資源是CPU。

disk屬性值說明:

rrqm/s:  每秒進行 merge 的讀操做數目。即 rmerge/s

wrqm/s:  每秒進行 merge 的寫操做數目。即 wmerge/s

r/s:  每秒完成的讀 I/O 設備次數。即 rio/s

w/s:  每秒完成的寫 I/O 設備次數。即 wio/s

rsec/s:  每秒讀扇區數。即 rsect/s

wsec/s:  每秒寫扇區數。即 wsect/s

rkB/s:  每秒讀K字節數。是 rsect/s 的一半,由於每扇區大小爲512字節。

wkB/s:  每秒寫K字節數。是 wsect/s 的一半。

avgrq-sz:  平均每次設備I/O操做的數據大小 (扇區)。

avgqu-sz:  平均I/O隊列長度。

await:  平均每次設備I/O操做的等待時間 (毫秒)。

svctm: 平均每次設備I/O操做的服務時間 (毫秒)。

%util:  一秒中有百分之多少的時間用於 I/O 操做,即被io消耗的cpu百分比

備註:若是 %util 接近 100%,說明產生的I/O請求太多,I/O系統已經滿負荷,該磁盤可能存在瓶頸。若是 svctm 比較接近 await,說明 I/O 幾乎沒有等待時間;若是 await 遠大於 svctm,說明I/O 隊列太長,io響應太慢,則須要進行必要優化。若是avgqu-sz比較大,也表示有當量io在等待。

實例2:定時顯示全部信息

命令:

iostat 2 3

輸出:

[root@CT1186 ~]#iostat 2 3
Linux 2.6.18-128.el5 (CT1186)   2012年12月28日
avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           8.30    0.02    5.07    0.17    0.00   86.44
Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda              22.73        43.70       487.42  674035705 7517947296
sda1              0.00         0.00         0.00       2658        536
sda2              0.11         3.74         3.51   57721595   54202216
sda3              0.98         0.61        17.51    9454172  270023608
sda4              0.00         0.00         0.00          6          0
sda5              6.95         0.12       108.73    1924834 1677125640
sda6              2.20         0.18        31.22    2837260  481488152
sda7             12.48        39.04       326.44  602094508 5035107144
avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           8.88    0.00    7.94    0.19    0.00   83.00
Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               6.00         0.00       124.00          0        248
sda1              0.00         0.00         0.00          0          0
sda2              0.00         0.00         0.00          0          0
sda3              0.00         0.00         0.00          0          0
sda4              0.00         0.00         0.00          0          0
sda5              0.00         0.00         0.00          0          0
sda6              0.00         0.00         0.00          0          0
sda7              6.00         0.00       124.00          0        248
avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           9.12    0.00    7.81    0.00    0.00   83.07
Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda               4.00         0.00        84.00          0        168
sda1              0.00         0.00         0.00          0          0
sda2              0.00         0.00         0.00          0          0
sda3              0.00         0.00         0.00          0          0
sda4              0.00         0.00         0.00          0          0
sda5              0.00         0.00         0.00          0          0
sda6              4.00         0.00        84.00          0        168
sda7              0.00         0.00         0.00          0          0

說明:

每隔 2秒刷新顯示,且顯示3次

實例3:顯示指定磁盤信息

命令:

iostat -d sda1

輸出:

[root@CT1186 ~]#iostat -d sda1
Linux 2.6.18-128.el5 (CT1186)   2012年12月28日
Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtn
sda1              0.00         0.00         0.00       2658        536

實例4:以M爲單位顯示全部信息

命令:

iostat -m

輸出:

[root@CT1186 ~]# iostat -m
Linux 2.6.18-128.el5 (CT1186)   2012年12月28日
avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           8.30    0.02    5.07    0.17    0.00   86.44
Device:            tps    MB_read/s    MB_wrtn/s    MB_read    MB_wrtn
sda              22.72         0.02         0.24     329119    3670881
sda1              0.00         0.00         0.00          1          0
sda2              0.11         0.00         0.00      28184      26465
sda3              0.98         0.00         0.01       4616     131848
sda4              0.00         0.00         0.00          0          0
sda5              6.95         0.00         0.05        939     818911
sda6              2.20         0.00         0.02       1385     235102
sda7             12.48         0.02         0.16     293991    2458553

說明:

實例5:查看TPS和吞吐量信息

命令:

iostat -d -k 1 1

輸出:

[root@CT1186 ~]# iostat -d -k 1 1
Linux 2.6.18-128.el5 (CT1186)   2012年12月28日
Device:            tps    kB_read/s    kB_wrtn/s    kB_read    kB_wrtn
sda              22.72        21.85       243.71  337017916 3758984340
sda1              0.00         0.00         0.00       1329        268
sda2              0.11         1.87         1.76   28860797   27101108
sda3              0.98         0.31         8.75    4727086  135012508
sda4              0.00         0.00         0.00          3          0
sda5              6.95         0.06        54.37     962481  838566148
sda6              2.20         0.09        15.61    1418630  240744712
sda7             12.48        19.52       163.22  301047254 2517559596

說明:

tps:該設備每秒的傳輸次數(Indicate the number of transfers per second that were issued to the device.)。「一次傳輸」意思是「一次I/O請求」。多個邏輯請求可能會被合併爲「一次I/O請求」。「一次傳輸」請求的大小是未知的。

kB_read/s:每秒從設備(drive expressed)讀取的數據量;

kB_wrtn/s:每秒向設備(drive expressed)寫入的數據量;

kB_read:讀取的總數據量;kB_wrtn:寫入的總數量數據量;

這些單位都爲Kilobytes。

上面的例子中,咱們能夠看到磁盤sda以及它的各個分區的統計數據,當時統計的磁盤總TPS是22.73,下面是各個分區的TPS。(由於是瞬間值,因此總TPS並不嚴格等於各個分區TPS的總和)

實例6:查看設備使用率(%util)、響應時間(await)

命令:

iostat -d -x -k 1 1

輸出:

[root@CT1186 ~]# iostat -d -x -k 1 1
Linux 2.6.18-128.el5 (CT1186)   2012年12月28日
Device:         rrqm/s   wrqm/s   r/s   w/s    rkB/s    wkB/s avgrq-sz avgqu-sz   await  svctm  %util
sda               0.44    38.59  0.40 22.32    21.85   243.71    23.37     0.04    1.78   4.20   9.54
sda1              0.00     0.00  0.00  0.00     0.00     0.00    18.90     0.00    8.26   6.46   0.00
sda2              0.36     0.43  0.11  0.01     1.87     1.76    63.57     0.01   63.75   1.94   0.02
sda3              0.00     1.24  0.04  0.95     0.31     8.75    18.42     0.04   39.77   8.73   0.86
sda4              0.00     0.00  0.00  0.00     0.00     0.00     2.00     0.00   19.67  19.67   0.00
sda5              0.00     6.65  0.00  6.94     0.06    54.37    15.67     0.26   36.81   4.48   3.11
sda6              0.00     1.71  0.01  2.19     0.09    15.61    14.29     0.03   12.40   5.84   1.28
sda7              0.08    28.56  0.25 12.24    19.52   163.22    29.28     0.27   21.46   5.00   6.25

說明:

rrqm/s  每秒進行 merge 的讀操做數目.即 delta(rmerge)/s

wrqm/s 每秒進行 merge 的寫操做數目.即 delta(wmerge)/s

r/s  每秒完成的讀 I/O 設備次數.即 delta(rio)/s

w/s  每秒完成的寫 I/O 設備次數.即 delta(wio)/s

rsec/s  每秒讀扇區數.即 delta(rsect)/s

wsec/s 每秒寫扇區數.即 delta(wsect)/s

rkB/s  每秒讀K字節數.是 rsect/s 的一半,由於每扇區大小爲512字節.(須要計算)

wkB/s  每秒寫K字節數.是 wsect/s 的一半.(須要計算)

avgrq-sz平均每次設備I/O操做的數據大小 (扇區).delta(rsect+wsect)/delta(rio+wio)

avgqu-sz平均I/O隊列長度.即 delta(aveq)/s/1000 (由於aveq的單位爲毫秒).

await  平均每次設備I/O操做的等待時間 (毫秒).即 delta(ruse+wuse)/delta(rio+wio)

svctm 平均每次設備I/O操做的服務時間 (毫秒).即 delta(use)/delta(rio+wio)

%util 一秒中有百分之多少的時間用於 I/O 操做,或者說一秒中有多少時間 I/O 隊列是非空的即 delta(use)/s/1000 (由於use的單位爲毫秒)

若是 %util 接近 100%說明產生的I/O請求太多I/O系統已經滿負荷該磁盤可能存在瓶頸

隊列長度(avgqu-sz)也可做爲衡量系統 I/O 負荷的指標但因爲 avgqu-sz 是按照單位時間的平均值因此不能反映瞬間的 I/O 洪水

       形象的比喻
       r/s+w/s 相似於交款人的總數
      平均隊列長度(avgqu-sz)相似於單位時間裏平均排隊人的個數
      平均服務時間(svctm)相似於收銀員的收款速度
      平均等待時間(await)相似於平均每人的等待時間
      平均I/O數據(avgrq-sz)相似於平均每人所買的東西多少
       I/O 操做率 (%util)相似於收款臺前有人排隊的時間比例

相關文章
相關標籤/搜索