介绍下Linux的3个常用I/O相关命令,解决I/O压力过大问题时用iostat,查看磁盘的I/O状态用iotop,查看I/O进程排名用lsof

一、iostat

iostat工具将对系统的磁盘操作活动进行监视。它的特点是汇报磁盘活动统计情况,同时也会汇报出CPU使用情况。要想使用iostat命令,需要安装sysstat软件

[root@localhost ~]# yum -y install sysstat
[root@localhost ~]# iostat
Linux 5.14.0-162.6.1.el9_1.x86_64 (localhost.localdomain)       12/02/22        _x86_64_        (2 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
1.75    0.02    5.84    0.60    0.00   91.79

Device             tps    kB_read/s    kB_wrtn/s    kB_dscd/s    kB_read    kB_wrtn    kB_dscd
dm-0             73.70      2078.84       358.65         0.00     162919      28107          0
dm-1              1.26        29.96         0.00         0.00       2348          0          0
nvme0n1         104.45      2809.71       385.01         0.00     220197      30173          0
sr0               1.03        40.12         0.00         0.00       3144          0          0

输出信息:

avg-cpu段

%user: 用户程序占用CPU的百分比
%nice: nice操作占用CPU的百分比
%system: 系统占用CPU的百分比
%iowait: CPU等待硬件I/O时占用CPU百分比
%idle: CPU空闲时间的百分比

Device段

tps: 每秒钟I/O请求数
kB_read /s: 每秒读取的块数
kB_wrtn/s: 每秒写入的块数
kB_read: 读入的块总数
kB_wrtn: 写入的块总数

常用参数

-c 仅显示CPU统计信息,与-d互斥
-d 仅显示磁盘统计信息,与-c互斥
-k 以K为单位显示每秒的磁盘请求数,默认单位块
-p 设备名 | ALL,只显示某个设备的信息,或者全部设备
-x 输出扩展信息
sec 间隔sec秒显示一次

二、iotop

iotop用来监视磁盘 I/O 使用状况的 top 类工具,具有与 top 相似的 UI,其中包括 PID、用户、I/O、进程等相关信息。iotop不是系统自带的命令,要想使用iotop命令,需要安装iotop软件。

[root@localhost ~]# yum -y install iotop
[root@localhost ~]# iotop
Total DISK READ :       0.00 B/s | Total DISK WRITE :       0.00 B/s
Actual DISK READ:       0.00 B/s | Actual DISK WRITE:       0.00 B/s
TID  PRIO  USER     DISK READ DISK WRITE>    COMMAND                                                                                                     
1 be/4 root        0.00 B/s    0.00 B/s systemd --switched-root --system --deserialize 28
2 be/4 root        0.00 B/s    0.00 B/s [kthreadd]
3 be/4 root        0.00 B/s    0.00 B/s [rcu_gp]
4 be/4 root        0.00 B/s    0.00 B/s [rcu_par_gp]
5 be/4 root        0.00 B/s    0.00 B/s [netns]
7 be/4 root        0.00 B/s    0.00 B/s [kworker/0:0H-events_highpri]
9 be/4 root        0.00 B/s    0.00 B/s [kworker/0:1H-events_highpri]
10 be/4 root        0.00 B/s    0.00 B/s [mm_percpu_wq]
12 be/4 root        0.00 B/s    0.00 B/s [rcu_tasks_kthre]
13 be/4 root        0.00 B/s    0.00 B/s [rcu_tasks_rude_]
14 be/4 root        0.00 B/s    0.00 B/s [rcu_tasks_trace]
15 be/4 root        0.00 B/s    0.00 B/s [ksoftirqd/0]
16 be/4 root        0.00 B/s    0.00 B/s [rcu_preempt]
17 be/4 root        0.00 B/s    0.00 B/s [migration/0]
19 be/4 root        0.00 B/s    0.00 B/s [cpuhp/0]
20 be/4 root        0.00 B/s    0.00 B/s [cpuhp/1]

通过输出结果,我们可以清楚地知晓是什么程序在读写磁盘,速度以及命令行,pid 等信息。

常用参数

-b 批量显示,无交互。主要用作记录到文件
-n NUM 显示NUM次,主要用于非交互式模式
-d SEC 间隔SEC秒显示一次
-p PID 监控的进程pid
-u USER 监控的进程用户

三、lsof

lsof(list open files)是一个列出当前系统打开文件的工具,lsof 需要访问核心内存和各种文件,所以必须以root身份执行才能充分发挥优势。lsof不是系统自带的命令,要想使用lsof命令,需要安装lsof软件。

[root@localhost ~]# yum -y install lsof
[root@localhost ~]# lsof
COMMAND    PID TID TASKCMD     USER   FD      TYPE             DEVICE SIZE/OFF       NODE NAME
systemd      1                 root  cwd       DIR              253,0      235        128 /
systemd      1                 root  rtd       DIR              253,0      235        128 /
systemd      1                 root  txt       REG              253,0  1945080   67508326 /usr/lib/systemd/systemd
systemd      1                 root  mem       REG              253,0    45416   67348788 /usr/lib64/libffi.so.8.1.0
systemd      1                 root  mem       REG              253,0   153600   67348802 /usr/lib64/libgpg-error.so.0.32.0
systemd      1                 root  mem       REG              253,0    28568   67348896 /usr/lib64/libattr.so.1.1.2501
systemd      1                 root  mem       REG              253,0   102568   67348636 /usr/lib64/libz.so.1.2.11
systemd      1                 root  mem       REG              253,0    32528   67348775 /usr/lib64/libcap-ng.so.0.0.0
systemd      1                 root  mem       REG              253,0    41064   67420376 /usr/lib64/libeconf.so.0.4.1
systemd      1                 root  mem       REG              253,0   637880   67348851 /usr/lib64/libpcre2-8.so.0.11.0
systemd      1                 root  mem       REG              253,0   906176   67323555 /usr/lib64/libm.so.6
systemd      1                 root  mem       REG              253,0   178744   67348640 /usr/lib64/liblzma.so.5.2.5
systemd      1                 root  mem       REG              253,0   882384   67348653 /usr/lib64/libzstd.so.1.5.1
systemd      1                 root  mem       REG              253,0  1293840   67348792 /usr/lib64/libp11-kit.so.0.3.0
systemd      1                 root  mem       REG              253,0  4459096   67420748 /usr/lib64/libcrypto.so.3.0.1
systemd      1                 root  mem       REG              253,0   144144   67348822 /usr/lib64/liblz4.so.1.9.3
systemd      1                 root  mem       REG              253,0  1305536   67348868 /usr/lib64/libgcrypt.so.20.4.0
systemd      1                 root  mem       REG              253,0   201832   67348663 /usr/lib64/libcrypt.so.2.0.0
systemd      1                 root  mem       REG  

参数说明:

PID:进程标识符
USER:进程所有者
FD:文件描述符
TYPE:文件类型,如DIR、REG等
DEVICE:指定磁盘的名称
SIZE:文件的大小
NODE:索引节点
NAME:打开文件的确切名称常用参数lsofabc.txt显示开启文件abc.txt的进程

常见使用方法:

lsof -c abc 显示abc进程现在打开的文件
lsof -p 1234 列出进程号为1234的进程所打开的文件
lsof -g gid 显示归属gid的进程情况
lsof +d /DIR/ 显示DIR目录下被进程打开的文件
END

最后修改:2024 年 11 月 21 日
如果觉得我的文章对你有用,请随意赞赏