你知道在 Linux 中我們使用什麼工具檢修和監控實時的磁碟活動嗎?如果 Linux 系統效能變慢,我們會用 top 命令 來檢視系統效能。它被用來檢查是什麼進程在伺服器上佔有如此高的使用率,對於大多數 Linux 系統管理員來說很常見,現實世界中被 Linux 系統管理員廣泛採用。
如果在進程輸出中你沒有看到很大的不同,你仍然有選擇檢視其他東西。我會建議你在 top
輸出中檢查 wa
狀態,因為大多數時間裡伺服器效能由於在硬碟上的高 I/O 讀和寫降低了效能。如果它很高或者波動,很可能就是它造成的。因此,我們需要檢查硬碟上的 I/O 活動。
我們可以在 Linux 中使用 iotop
和 iostat
命令監控所有的磁碟和檔案系統的磁碟 I/O 統計。
iotop
是一個類似 top
的工具,用來顯示實時的磁碟活動。
iotop
監控 Linux 核心輸出的 I/O 使用資訊,並且顯示一個系統中進程或執行緒的當前 I/O 使用情況。
它顯示每個進程/執行緒讀寫 I/O 頻寬。它同樣顯示當等待換入和等待 I/O 的執行緒/進程花費的時間的百分比。
Total DISK READ
和 Total DISK WRITE
的值一方面表示了進程和核心執行緒之間的總的讀寫頻寬,另一方面也表示核心塊裝置子系統的。
Actual DISK READ
和 Actual DISK WRITE
的值表示在核心塊裝置子系統和下面硬體(HDD、SSD 等等)對應的實際磁碟 I/O 頻寬。
我們可以輕鬆在包管理器的幫助下安裝,因為該軟體包在所有的 Linux 發行版倉庫中都可以獲得。
對於 Fedora 系統,使用 DNF 命令 來安裝 iotop
。
$ sudo dnf install iotop
對於 Debian/Ubuntu 系統,使用 API-GET 命令 或者 APT 命令 來安裝 iotop
。
$ sudo apt install iotop
對於基於 Arch Linux 的系統,使用 Pacman Command 來安裝 iotop
。
$ sudo pacman -S iotop
對於 RHEL/CentOS 的系統,使用 YUM Command 來安裝 iotop
。
$ sudo yum install iotop
對於使用 openSUSE Leap 的系統,使用 Zypper Command 來安裝 iotop
。
$ sudo zypper install iotop
iotop
命令有很多引數來檢查關於磁碟 I/O 的變化:
# iotop
如果你想檢查那個進程實際在做 I/O,那麼執行 iotop
命令加上 -o
或者 --only
引數。
# iotop --only
細節:
IO
:它顯示每個進程的 I/O 利用率,包含磁碟和交換。SWAPIN
: 它只顯示每個進程的交換使用率。iostat
被用來報告中央處理單元(CPU)的統計和裝置與分割區的輸出/輸出的統計。
iostat
命令通過觀察與它們平均傳輸率相關的裝置活躍時間來監控系統輸入/輸出裝置負載。
iostat
命令生成的報告可以被用來改變系統設定來更好的平衡物理磁碟之間的輸入/輸出負載。
所有的統計都在 iostat
命令每次執行時被報告。該報告包含一個 CPU 頭部,後面是一行 CPU 統計。
在多處理器系統中,CPU 統計被計算為系統層面的所有處理器的平均值。裝置頭行後緊跟顯示每個設定的裝置一行的統計。
iostat
命令生成兩種型別的報告,CPU 利用率報告和裝置利用率報告。
iostat
工具是 sysstat
包的一部分,所以我們可以輕鬆地在包管理器地幫助下安裝,因為在所有的 Linux 發行版的倉庫都是可以獲得的。
對於 Fedora 系統,使用 DNF Command 來安裝 sysstat
。
$ sudo dnf install sysstat
對於 Debian/Ubuntu 系統,使用 APT-GET Command 或者 APT Command 來安裝 sysstat
。
$ sudo apt install sysstat
對於基於 Arch Linux 的系統,使用 Pacman Command 來安裝 sysstat
。
$ sudo pacman -S sysstat
對於 RHEL/CentOS 系統,使用 YUM Command 來安裝 sysstat
。
$ sudo yum install sysstat
對於 openSUSE Leap 系統,使用 Zypper Command 來安裝 sysstat
。
$ sudo zypper install sysstat
在 iostat
命令中有很多引數來檢查關於 I/O 和 CPU 的變化統計資訊。
不加引數執行 iostat
命令會看到完整的系統統計。
# iostatLinux 4.19.32-1-MANJARO (daygeek-Y700) Thursday 18 April 2019 _x86_64_ (8 CPU)avg-cpu: %user %nice %system %iowait %steal %idle 29.45 0.02 16.47 0.12 0.00 53.94Device tps kB_read/s kB_wrtn/s kB_dscd/s kB_read kB_wrtn kB_dscdnvme0n1 6.68 126.95 124.97 0.00 58420014 57507206 0sda 0.18 6.77 80.24 0.00 3115036 36924764 0loop0 0.00 0.00 0.00 0.00 2160 0 0loop1 0.00 0.00 0.00 0.00 1093 0 0loop2 0.00 0.00 0.00 0.00 1077 0 0
執行 iostat
命令加上 -d
引數檢視所有裝置的 I/O 統計。
# iostat -dLinux 4.19.32-1-MANJARO (daygeek-Y700) Thursday 18 April 2019 _x86_64_ (8 CPU)Device tps kB_read/s kB_wrtn/s kB_dscd/s kB_read kB_wrtn kB_dscdnvme0n1 6.68 126.95 124.97 0.00 58420030 57509090 0sda 0.18 6.77 80.24 0.00 3115292 36924764 0loop0 0.00 0.00 0.00 0.00 2160 0 0loop1 0.00 0.00 0.00 0.00 1093 0 0loop2 0.00 0.00 0.00 0.00 1077 0 0
執行 iostat
命令加上 -p
引數檢視所有的裝置和分割區的 I/O 統計。
# iostat -pLinux 4.19.32-1-MANJARO (daygeek-Y700) Thursday 18 April 2019 _x86_64_ (8 CPU)avg-cpu: %user %nice %system %iowait %steal %idle 29.42 0.02 16.45 0.12 0.00 53.99Device tps kB_read/s kB_wrtn/s kB_dscd/s kB_read kB_wrtn kB_dscdnvme0n1 6.68 126.94 124.96 0.00 58420062 57512278 0nvme0n1p1 6.40 124.46 118.36 0.00 57279753 54474898 0nvme0n1p2 0.27 2.47 6.60 0.00 1138069 3037380 0sda 0.18 6.77 80.23 0.00 3116060 36924764 0sda1 0.00 0.01 0.00 0.00 3224 0 0sda2 0.18 6.76 80.23 0.00 3111508 36924764 0loop0 0.00 0.00 0.00 0.00 2160 0 0loop1 0.00 0.00 0.00 0.00 1093 0 0loop2 0.00 0.00 0.00 0.00 1077 0 0
執行 iostat
命令加上 -x
引數顯示所有裝置的詳細的 I/O 統計資訊。
# iostat -xLinux 4.19.32-1-MANJARO (daygeek-Y700) Thursday 18 April 2019 _x86_64_ (8 CPU)avg-cpu: %user %nice %system %iowait %steal %idle 29.41 0.02 16.45 0.12 0.00 54.00Device r/s rkB/s rrqm/s %rrqm r_await rareq-sz w/s wkB/s wrqm/s %wrqm w_await wareq-sz d/s dkB/s drqm/s %drqm d_await dareq-sz aqu-sz %utilnvme0n1 2.45 126.93 0.60 19.74 0.40 51.74 4.23 124.96 5.12 54.76 3.16 29.54 0.00 0.00 0.00 0.00 0.00 0.00 0.31 30.28sda 0.06 6.77 0.00 0.00 8.34 119.20 0.12 80.23 19.94 99.40 31.84 670.73 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.13loop0 0.00 0.00 0.00 0.00 0.08 19.64 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00loop1 0.00 0.00 0.00 0.00 0.40 12.86 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00loop2 0.00 0.00 0.00 0.00 0.38 19.58 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00
執行 iostat
命令加上 -d [裝置名]
引數檢視具體裝置和它的分割區的 I/O 統計資訊。
# iostat -p [Device_Name]# iostat -p sdaLinux 4.19.32-1-MANJARO (daygeek-Y700) Thursday 18 April 2019 _x86_64_ (8 CPU)avg-cpu: %user %nice %system %iowait %steal %idle 29.38 0.02 16.43 0.12 0.00 54.05Device tps kB_read/s kB_wrtn/s kB_dscd/s kB_read kB_wrtn kB_dscdsda 0.18 6.77 80.21 0.00 3117468 36924764 0sda2 0.18 6.76 80.21 0.00 3112916 36924764 0sda1 0.00 0.01 0.00 0.00 3224 0 0
執行 iostat
命令加上 -m
引數以 MB 為單位而不是 KB 檢視所有裝置的統計。預設以 KB 顯示輸出。
# iostat -mLinux 4.19.32-1-MANJARO (daygeek-Y700) Thursday 18 April 2019 _x86_64_ (8 CPU)avg-cpu: %user %nice %system %iowait %steal %idle 29.36 0.02 16.41 0.12 0.00 54.09Device tps MB_read/s MB_wrtn/s MB_dscd/s MB_read MB_wrtn MB_dscdnvme0n1 6.68 0.12 0.12 0.00 57050 56176 0sda 0.18 0.01 0.08 0.00 3045 36059 0loop0 0.00 0.00 0.00 0.00 2 0 0loop1 0.00 0.00 0.00 0.00 1 0 0loop2 0.00 0.00 0.00 0.00 1 0 0
執行 iostat
命令使用特定的間隔使用如下的格式。在這個例子中,我們打算以 5 秒捕獲的間隔捕獲兩個報告。
# iostat [Interval] [Number Of Reports]# iostat 5 2Linux 4.19.32-1-MANJARO (daygeek-Y700) Thursday 18 April 2019 _x86_64_ (8 CPU)avg-cpu: %user %nice %system %iowait %steal %idle 29.35 0.02 16.41 0.12 0.00 54.10Device tps kB_read/s kB_wrtn/s kB_dscd/s kB_read kB_wrtn kB_dscdnvme0n1 6.68 126.89 124.95 0.00 58420116 57525344 0sda 0.18 6.77 80.20 0.00 3118492 36924764 0loop0 0.00 0.00 0.00 0.00 2160 0 0loop1 0.00 0.00 0.00 0.00 1093 0 0loop2 0.00 0.00 0.00 0.00 1077 0 0avg-cpu: %user %nice %system %iowait %steal %idle 3.71 0.00 2.51 0.05 0.00 93.73Device tps kB_read/s kB_wrtn/s kB_dscd/s kB_read kB_wrtn kB_dscdnvme0n1 19.00 0.20 311.40 0.00 1 1557 0sda 0.20 25.60 0.00 0.00 128 0 0loop0 0.00 0.00 0.00 0.00 0 0 0loop1 0.00 0.00 0.00 0.00 0 0 0loop2 0.00 0.00 0.00 0.00 0 0 0
執行 iostat
命令與 -N
引數來檢視 LVM 磁碟 I/O 統計報告。
# iostat -NLinux 4.15.0-47-generic (Ubuntu18.2daygeek.com) Thursday 18 April 2019 _x86_64_ (2 CPU)avg-cpu: %user %nice %system %iowait %steal %idle 0.38 0.07 0.18 0.26 0.00 99.12Device tps kB_read/s kB_wrtn/s kB_read kB_wrtnsda 3.60 57.07 69.06 968729 1172340sdb 0.02 0.33 0.00 5680 0sdc 0.01 0.12 0.00 2108 02g-2gvol1 0.00 0.07 0.00 1204 0
執行 nfsiostat
命令來檢視 Network File System(NFS)的 I/O 統計。
# nfsiostat