真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

每天一個linux命令(47):iostat命令-創(chuàng)新互聯(lián)

Linux系統(tǒng)中的 iostat是I/O statistics(輸入/輸出統(tǒng)計)的縮寫,iostat工具將對系統(tǒng)的磁盤操作活動進行監(jiān)視。它的特點是匯報磁盤活動統(tǒng)計情況,同時也會匯報出CPU使用情況。同vmstat一樣,iostat也有一個弱點,就是它不能對某個進程進行深入分析,僅對系統(tǒng)的整體情況進行分析。iostat屬于sysstat軟件包??梢杂脃um install sysstat 直接安裝。

創(chuàng)新互聯(lián)公司提供高防物理服務器租用、云服務器、香港服務器、成都移動云計算中心

1.命令格式:

iostat[參數(shù)][時間][次數(shù)]

2.命令功能:

  通過iostat方便查看CPU、網(wǎng)卡、tty設備、磁盤、CD-ROM 等等設備的活動情況, 負載信息。

3.命令參數(shù):

-C 顯示CPU使用情況

-d 顯示磁盤使用情況

-k 以 KB 為單位顯示

-m 以 M 為單位顯示

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

-n 顯示NFS 使用情況

-p[磁盤] 顯示磁盤和分區(qū)的情況

-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處在系統(tǒng)模式下的時間百分比。

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

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

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

備注:如果%iowait的值過高,表示硬盤存在I/O瓶頸,%idle值高,表示CPU較空閑,如果%idle值高但系統(tǒng)響應慢時,有可能是CPU等待分配內(nèi)存,此時應加大內(nèi)存容量。%idle值如果持續(xù)低于10,那么系統(tǒng)的CPU處理能力相對較低,表明系統(tǒng)中最需要解決的資源是CPU。

disk屬性值說明:

rrqm/s:  每秒進行 merge 的讀操作數(shù)目。即 rmerge/s

wrqm/s:  每秒進行 merge 的寫操作數(shù)目。即 wmerge/s

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

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

rsec/s:  每秒讀扇區(qū)數(shù)。即 rsect/s

wsec/s:  每秒寫扇區(qū)數(shù)。即 wsect/s

rkB/s:  每秒讀K字節(jié)數(shù)。是 rsect/s 的一半,因為每扇區(qū)大小為512字節(jié)。

wkB/s:  每秒寫K字節(jié)數(shù)。是 wsect/s 的一半。

avgrq-sz:  平均每次設備I/O操作的數(shù)據(jù)大小 (扇區(qū))。

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

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

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

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

備注:如果 %util 接近 100%,說明產(chǎn)生的I/O請求太多,I/O系統(tǒng)已經(jīng)滿負荷,該磁盤可能存在瓶頸。如果 svctm 比較接近 await,說明 I/O 幾乎沒有等待時間;如果 await 遠大于 svctm,說明I/O 隊列太長,io響應太慢,則需要進行必要優(yōu)化。如果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:顯示tty和Cpu信息

命令:

iostat -t

輸出:

復制代碼

[root@CT1186 ~]# iostat -t

Linux 2.6.18-128.el5 (CT1186)  2012年12月28日

Time: 14時58分35秒

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.41  674035705 7517957864

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  270024344

sda4        0.00     0.00     0.00      6      0

sda5        6.95     0.12    108.73   1924834 1677128808

sda6        2.20     0.18     31.22   2837260  481488712

sda7       12.48     39.04    326.44  602094508 5035113248

復制代碼

說明:

實例5:以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

復制代碼

說明:

實例6:查看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:該設備每秒的傳輸次數(shù)(Indicate the number of transfers per second that were issued to the device.)。“一次傳輸”意思是“一次I/O請求”。多個邏輯請求可能會被合并為“一次I/O請求”。“一次傳輸”請求的大小是未知的。

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

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

kB_read:讀取的總數(shù)據(jù)量;kB_wrtn:寫入的總數(shù)量數(shù)據(jù)量;

這些單位都為Kilobytes。

上面的例子中,我們可以看到磁盤sda以及它的各個分區(qū)的統(tǒng)計數(shù)據(jù),當時統(tǒng)計的磁盤總TPS是22.73,下面是各個分區(qū)的TPS。(因為是瞬間值,所以總TPS并不嚴格等于各個分區(qū)TPS的總和)

實例7:查看設備使用率(%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 的讀操作數(shù)目.即 delta(rmerge)/s

wrqm/s: 每秒進行 merge 的寫操作數(shù)目.即 delta(wmerge)/s

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

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

rsec/s:  每秒讀扇區(qū)數(shù).即 delta(rsect)/s

wsec/s: 每秒寫扇區(qū)數(shù).即 delta(wsect)/s

rkB/s:  每秒讀K字節(jié)數(shù).是 rsect/s 的一半,因為每扇區(qū)大小為512字節(jié).(需要計算)

wkB/s:  每秒寫K字節(jié)數(shù).是 wsect/s 的一半.(需要計算)

avgrq-sz:平均每次設備I/O操作的數(shù)據(jù)大小 (扇區(qū)).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%,說明產(chǎn)生的I/O請求太多,I/O系統(tǒng)已經(jīng)滿負荷,該磁盤可能存在瓶頸。

idle小于70% IO壓力就較大了,一般讀取速度有較多的wait。

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

另外 await 的參數(shù)也要多和 svctm 來參考。差的過高就一定有 IO 的問題。

avgqu-sz 也是個做 IO 調優(yōu)時需要注意的地方,這個就是直接每次操作的數(shù)據(jù)的大小,如果次數(shù)多,但數(shù)據(jù)拿的小的話,其實 IO 也會很小。如果數(shù)據(jù)拿的大,才IO 的數(shù)據(jù)會高。也可以通過 avgqu-sz × ( r/s or w/s ) = rsec/s or wsec/s。也就是講,讀定速度是這個來決定的。

svctm 一般要小于 await (因為同時等待的請求的等待時間被重復計算了),svctm 的大小一般和磁盤性能有關,CPU/內(nèi)存的負荷也會對其有影響,請求過多也會間接導致 svctm 的增加。await 的大小一般取決于服務時間(svctm) 以及 I/O 隊列的長度和 I/O 請求的發(fā)出模式。如果 svctm 比較接近 await,說明 I/O 幾乎沒有等待時間;如果 await 遠大于 svctm,說明 I/O 隊列太長,應用得到的響應時間變慢,如果響應時間超過了用戶可以容許的范圍,這時可以考慮更換更快的磁盤,調整內(nèi)核 elevator 算法,優(yōu)化應用,或者升級 CPU。

隊列長度(avgqu-sz)也可作為衡量系統(tǒng) I/O 負荷的指標,但由于 avgqu-sz 是按照單位時間的平均值,所以不能反映瞬間的 I/O 洪水。

    形象的比喻:

    r/s+w/s 類似于交款人的總數(shù)

   平均隊列長度(avgqu-sz)類似于單位時間里平均排隊人的個數(shù)

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

   平均等待時間(await)類似于平均每人的等待時間

   平均I/O數(shù)據(jù)(avgrq-sz)類似于平均每人所買的東西多少

    I/O 操作率 (%util)類似于收款臺前有人排隊的時間比例

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

   平均每次設備I/O操作只需要0.36毫秒完成,現(xiàn)在卻需要10.57毫秒完成,因為發(fā)出的 請求太多(每秒26.74個),假如請求時同時發(fā)出的,可以這樣計算平均等待時間:

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

    每秒發(fā)出的I/0請求很多,但是平均隊列就4,表示這些請求比較均勻,大部分處理還是比較及時。

  實例8:查看cpu狀態(tài)

  命令:

  iostat -c 1 3

  輸出:

復制代碼

[root@CT1186 ~]#  iostat -c 1 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

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

      8.64   0.00   5.38   0.00   0.00  85.98

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

      7.62   0.00   5.12   0.50   0.00  86.75

復制代碼

  說明:

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


文章標題:每天一個linux命令(47):iostat命令-創(chuàng)新互聯(lián)
標題路徑:http://weahome.cn/article/dpesph.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部