當(dāng)前位置:首頁 > IT技術(shù) > 移動(dòng)平臺(tái) > 正文

linux wa%過高,iostat查看io狀況
2021-08-09 19:08:16

在使用top命令的時(shí)候會(huì)看到這么一行:

linux wa%過高,iostat查看io狀況_ios

翻譯一下:

us:用戶態(tài)使用的cpu時(shí)間比

sy:系統(tǒng)態(tài)使用的cpu時(shí)間比

ni:用做nice加權(quán)的進(jìn)程分配的用戶態(tài)cpu時(shí)間比

id:空閑的cpu時(shí)間比

wacpu等待磁盤寫入完成時(shí)間

hi:硬中斷消耗時(shí)間

si:軟中斷消耗時(shí)間

st:虛擬機(jī)偷取時(shí)間

如果一臺(tái)機(jī)器看到wa特別高,那么一般說明是磁盤IO出現(xiàn)問題,可以使用iostat等命令繼續(xù)進(jìn)行詳細(xì)分析。

1, 安裝??iostat??

  yum install sysstat

之后就可以使用?iostat 命令了,

2,入門使用

  iostat -d -k 2

參數(shù) -d 表示,顯示設(shè)備(磁盤)使用狀態(tài);-k某些使用block為單位的列強(qiáng)制使用Kilobytes為單位;2表示,數(shù)據(jù)顯示每隔2秒刷新一次。

linux wa%過高,iostat查看io狀況_sed_02

?

tps:該設(shè)備每秒的傳輸次數(shù)(Indicate the number of transfers per second that were issued to the device.)。"一次傳輸"意思是"一次I/O請求"。多個(gè)邏輯請求可能會(huì)被合并為"一次I/O請求""一次傳輸"請求的大小是未知的。

?

kB_read/s:每秒從設(shè)備(drive expressed)讀取的數(shù)據(jù)量;
kB_wrtn/s:每秒向設(shè)備(drive expressed)寫入的數(shù)據(jù)量;
kB_read:讀取的總數(shù)據(jù)量;

kB_wrtn:寫入的總數(shù)量數(shù)據(jù)量;這些單位都為Kilobytes。

指定監(jiān)控的設(shè)備名稱為sda,該命令的輸出結(jié)果和上面命令完全相同。

?iostat -d sda 2

默認(rèn)監(jiān)控所有的硬盤設(shè)備,現(xiàn)在指定只監(jiān)控sda。?

3, -x 參數(shù)

iostat還有一個(gè)比較常用的選項(xiàng)-x,該選項(xiàng)將用于顯示和io相關(guān)的擴(kuò)展數(shù)據(jù)。

iostat -d -x -k 1 10

linux wa%過高,iostat查看io狀況_數(shù)據(jù)_03

輸出信息的含義

linux wa%過高,iostat查看io狀況_數(shù)據(jù)_04

rrqm/s:每秒這個(gè)設(shè)備相關(guān)的讀取請求有多少被Merge了(當(dāng)系統(tǒng)調(diào)用需要讀取數(shù)據(jù)的時(shí)候,VFS將請求發(fā)到各個(gè)FS,如果FS發(fā)現(xiàn)不同的讀取請求讀取的是相同Block的數(shù)據(jù),
FS會(huì)將這個(gè)請求合并Merge);
wrqm/s:每秒這個(gè)設(shè)備相關(guān)的寫入請求有多少被Merge了。

?

rsec/s:每秒讀取的扇區(qū)數(shù);

wsec/:每秒寫入的扇區(qū)數(shù)。

rKB/sThe number of read requests that were issued to the device per second;

wKB/sThe number of write requests that were issued to the device per second;

avgrq-sz 平均請求扇區(qū)的大小

avgqu-sz 是平均請求隊(duì)列的長度。毫無疑問,隊(duì)列長度越短越好。???

await? 每一個(gè)IO請求的處理的平均時(shí)間(單位是微秒毫秒)。這里可以理解為IO的響應(yīng)時(shí)間,一般地系統(tǒng)IO響應(yīng)時(shí)間應(yīng)該低于5ms,如果大于10ms就比較大了。

???????? 這個(gè)時(shí)間包括了隊(duì)列時(shí)間和服務(wù)時(shí)間,也就是說,一般情況下,await大于svctm,它們的差值越小,則說明隊(duì)列時(shí)間越短,反之差值越大,隊(duì)列時(shí)間越長,說明系統(tǒng)出了問題。

svctm??? 表示平均每次設(shè)備I/O操作的服務(wù)時(shí)間(以毫秒為單位)。如果svctm的值與await很接近,表示幾乎沒有I/O等待,磁盤性能很好,如果await的值遠(yuǎn)高于svctm的值,
      則表示I/O隊(duì)列等待太長,????????
      系統(tǒng)上運(yùn)行的應(yīng)用程序?qū)⒆兟?/span>
%util 在統(tǒng)計(jì)時(shí)間內(nèi)所有處理IO時(shí)間,除以總共統(tǒng)計(jì)時(shí)間。例如,如果統(tǒng)計(jì)間隔1秒,該設(shè)備有0.8秒在處理IO,
    而0.2秒閑置,那么該設(shè)備的%util = 0.8/1 = 80%,
    所以該參數(shù)暗示了設(shè)備的繁忙程度
    。一般地,如果該參數(shù)是100%表示設(shè)備已經(jīng)接近滿負(fù)荷運(yùn)行了
   ?。ó?dāng)然如果是多磁盤,即使%util100%,因?yàn)榇疟P的并發(fā)能力,所以磁盤使用未必就到了瓶頸)。

linux wa%過高,iostat查看io狀況_數(shù)據(jù)_04

?

4,?常見用法

iostat -d -k 1 10???????? #查看TPS和吞吐量信息(磁盤讀寫速度單位為KB)

iostat -d -m 2??????????? #查看TPS和吞吐量信息(磁盤讀寫速度單位為MB)

iostat -d -x -k 1 10????? #查看設(shè)備使用率(%util)、響應(yīng)時(shí)間(await iostat -c 1 10 #查看cpu狀態(tài)

?

5, 實(shí)例分析

linux wa%過高,iostat查看io狀況_響應(yīng)時(shí)間_06

iostat -d -k 1 | grep vda

Device:??????????? tps??? kB_read/s??? kB_wrtn/s??? kB_read??? kB_wrtn

sda10????? ??????60.72??????? 18.95??????? 71.53? 395637647 1493241908

sda10?????????? 299.02????? 4266.67?????? 129.41?????? 4352??????? 132

sda10?????????? 483.84????? 4589.90????? 4117.17?????? 4544?????? 4076

sda10?????????? 218.00????? 3360.00?????? 100.00???? ??3360??????? 100

sda10?????????? 546.00????? 8784.00?????? 124.00?????? 8784??????? 124

sda10?????????? 827.00???? 13232.00?????? 136.00????? 13232??????? 136

linux wa%過高,iostat查看io狀況_ios_07

上面看到,磁盤每秒傳輸次數(shù)平均約400;每秒磁盤讀取約5MB,寫入約1MB

?

?

iostat -d -x -k 1

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

sda????????? 1.56? 28.31? 7.84 31.50?? 43.65??? 3.16??? 21.82???? 1.58???? 1.19???? 0.03??? 0.80?? 2.61? 10.29

sda????????? 1.98? 24.75 419.80? 6.93 13465.35? 253.47? 6732.67?? 126.73??? 32.15???? 2.00??? 4.70?? 2.00? 85.25

sda???????? ?3.06? 41.84 444.90 54.08 14204.08 2048.98? 7102.04? 1024.49??? 32.57???? 2.10??? 4.21?? 1.85? 92.24

可以看到磁盤的平均響應(yīng)時(shí)間<5ms,磁盤使用率>80。磁盤響應(yīng)正常,但是已經(jīng)很繁忙了。

linux wa%過高,iostat查看io狀況_sed_08

可以看到磁盤的平均響應(yīng)時(shí)間<5ms,磁盤使用率>90。磁盤響應(yīng)正常,但是已經(jīng)很繁忙了。

await? 每一個(gè)IO請求的處理的平均時(shí)間(單位是微秒毫秒)。這里可以理解為IO的響應(yīng)時(shí)間,一般地系統(tǒng)IO響應(yīng)時(shí)間應(yīng)該低于5ms,如果大于10ms就比較大了

svctm??? 表示平均每次設(shè)備I/O操作的服務(wù)時(shí)間(以毫秒為單位)。如果svctm的值與await很接近,表示幾乎沒有I/O等待,磁盤性能很好,如果await的值遠(yuǎn)高于svctm的值,則表示I/O隊(duì)列等待太長,? 系統(tǒng)上運(yùn)行的應(yīng)用程序?qū)⒆兟?/span>

%util 在統(tǒng)計(jì)時(shí)間內(nèi)所有處理IO時(shí)間,除以總共統(tǒng)計(jì)時(shí)間。所以該參數(shù)暗示了設(shè)備的繁忙程度。一般地,如果該參數(shù)是100%表示設(shè)備已經(jīng)接近滿負(fù)荷運(yùn)行了(當(dāng)然如果是多磁盤,即使%util100%,因?yàn)榇疟P的并發(fā)能力,所以磁盤使用未必就到了瓶頸)。


也可以使用下面的命令,同時(shí)顯示cpu和磁盤的使用情況

linux wa%過高,iostat查看io狀況_用戶態(tài)_09

等待時(shí)間超過5ms, 磁盤io有問題

linux wa%過高,iostat查看io狀況_數(shù)據(jù)_10

?

?

本文摘自 :https://blog.51cto.com/u

開通會(huì)員,享受整站包年服務(wù)立即開通 >