IOSTAT命令

IOSTAT命令ios

 

IOSTATI/O statistics(輸入/輸出統計)的縮寫,iostat能夠顯示出磁盤活動和cpu的使用狀況,屬於sysstat軟件包。算法

 

1.命令格式:

 iostat  [參數]  [時間間隔]  [次數]服務器

2.命令參數:

-c    只顯示cpu的使用ide

-d    只顯示磁盤的使用性能

-k   以K爲單位顯示統計信息優化

-m   以M爲單位顯示統計信息spa

-n    顯示nfs的塊設備使用狀況隊列

-p    顯示每一個分區的使用狀況進程

-t    顯示當前統計的時間內存

-x    顯示統計的詳細信息

3.具體使用

1)  iostat   顯示出cpu使用和磁盤每一個分區的使用

[root@mail~]# iostat 

Linux2.6.18-194.el5 (mail.xywy.com)   08/04/15

avg-cpu:  %user  %nice %system %iowait  %steal   %idle

           9.36    0.00   4.56    6.84    0.00  79.24

 

Device:            tps   Blk_read/s  Blk_wrtn/s   Blk_read   Blk_wrtn

sda             308.71       120.75      4694.45 4306019091 167410799798

sda1              0.00         0.00         0.00       3178        134

sda2            261.35        45.17      4149.32 1610898738 147970650112

sda3              0.00         0.00         0.00       1630       1632

sda4              0.00         0.00         0.00          8          0

sda5              0.00         0.00         0.00       9658        152

sda6             47.36        75.57       545.13 2695105335 19440147768

輸出解釋:

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 1 5 自定義顯示間隔和次數

[root@mail~]# iostat -c  1 5 -t

Linux2.6.18-194.el5 (mail.xywy.com)   08/04/15

Time:18:58:18

avg-cpu:  %user  %nice %system %iowait  %steal   %idle

           9.36    0.00    4.56   6.84    0.00   79.24

Time:18:58:19

avg-cpu:  %user  %nice %system %iowait  %steal   %idle

           0.00    0.00    0.50  12.00    0.00   87.50

Time:18:58:20

avg-cpu:  %user  %nice %system %iowait  %steal   %idle

           0.12    0.00    0.62  11.97    0.00   87.28

Time:18:58:21

avg-cpu:  %user  %nice %system %iowait  %steal   %idle

           6.76    0.00    3.38  21.15    0.00   68.71

Time:18:58:22

avg-cpu:  %user  %nice %system %iowait  %steal   %idle

           9.75    0.00   4.25   27.38    0.00  58.63

3)查看設備使用率和響應時間

[root@mail~]# iostat -d -x -k 1 1

Linux2.6.18-194.el5 (mail.xywy.com)   08/04/15

 

Device:         rrqm/s   wrqm/s  r/s   w/s    rkB/s   wkB/s avgrq-sz avgqu-sz  await  svctm  %util

sda               0.46   280.89 2.89 305.81    60.37  2347.22   15.60     0.08    0.65  0.29   8.97

sda1              0.00     0.00 0.00  0.00     0.00    0.00     3.92     0.00  39.08  38.68   0.00

sda2              0.10   259.62 2.34 259.01    22.59  2074.66   16.05     0.01    0.50  0.28   7.19

sda3              0.00     0.00 0.00  0.00     0.00    0.00    54.37     0.00 111.78  41.75   0.00

sda4              0.00     0.00 0.00  0.00     0.00    0.00     2.00     0.00  19.00  19.00   0.00

sda5              0.00     0.00 0.00  0.00     0.00    0.00    12.59     0.00  54.88  54.22   0.00

sda6              0.36    21.27 0.55 46.80    37.79   272.56   13.11     0.07    1.48  2.18  10.30

 

說明:

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系統已經滿負荷,該磁盤可能存在瓶頸。

idle小於70% IO壓力就較大了,通常讀取速度有較多的wait。

同時能夠結合vmstat 查看查看b參數(等待資源的進程數)和wa參數(IO等待所佔用的CPU時間的百分比,高過30%時IO壓力高)。

另外 await 的參數也要多和 svctm 來參考。差的太高就必定有 IO 的問題。

avgqu-sz也是個作 IO 調優時須要注意的地方,這個就是直接每次操做的數據的大小,若是次數多,但數據拿的小的話,其實 IO 也會很小。若是數據拿的大,才IO 的數據會高。也能夠經過 avgqu-sz × ( r/s or w/s ) = rsec/s orwsec/s。也就是講,讀定速度是這個來決定的。

svctm通常要小於 await(由於同時等待的請求的等待時間被重複計算了),svctm 的大小通常和磁盤性能有關,CPU/內存的負荷也會對其有影響,請求過多也會間接致使 svctm 的增長。await 的大小通常取決於服務時間(svctm) 以及 I/O 隊列的長度和 I/O 請求的發出模式。若是 svctm 比較接近 await,說明I/O 幾乎沒有等待時間;若是 await 遠大於 svctm,說明 I/O 隊列太長,應用獲得的響應時間變慢,若是響應時間超過了用戶能夠允許的範圍,這時能夠考慮更換更快的磁盤,調整內核 elevator 算法,優化應用,或者升級 CPU。

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

       形象的比喻:

       r/s+w/s 相似於交款人的總數

      平均隊列長度(avgqu-sz)相似於單位時間裏平均排隊人的個數

      平均服務時間(svctm)相似於收銀員的收款速度

      平均等待時間(await)相似於平均每人的等待時間

      平均I/O數據(avgrq-sz)相似於平均每人所買的東西多少

       I/O 操做率 (%util)相似於收款臺前有人排隊的時間比例

 

       設備IO操做:總IO(io)/s = r/s(讀) +w/s(寫) =1.46 + 25.28=26.74

      平均每次設備I/O操做只須要0.36毫秒完成,如今卻須要10.57毫秒完成,由於發出的  請求太多(每秒26.74個),假如請求時同時發出的,能夠這樣計算平均等待時間:

      平均等待時間=單個I/O服務器時間*(1+2+...+請求總數-1)/請求總數

       每秒發出的I/0請求不少,可是平均隊列就4,表示這些請求比較均勻,大部分處理仍是比較及時。

相關文章
相關標籤/搜索