Linux磁盘读写慢需四步排查:先用iostat确认硬盘负载,再用iotop定位高IO进程,接着用lsof和strace分析具体读写文件及系统调用,最后检查IO调度器匹配性与硬盘健康状态。

Linux磁盘读写慢,不能只盯着“换硬盘”或“加内存”,得先理清IO路径上的关键节点:是不是硬盘真忙?谁在猛写?写的是什么?调度策略配对了吗?硬件本身还健康吗?下面四步层层递进,帮你把问题从表象挖到根上。
确认硬盘是否真的处于高负载
别凭感觉判断“慢”,先看数据。运行 iostat -x 1,重点关注三列:
- %util:持续接近或超过95%,说明磁盘基本满负荷运转;
- await:平均每次I/O请求等待时间,超过20ms就值得警惕,超50ms大概率存在瓶颈;
- r/s 和 w/s:每秒读/写请求数,结合设备类型看是否合理(比如机械盘随机写超100 IOPS就已吃紧)。
如果 %util 很低但 await 很高,可能是队列堆积或调度策略不匹配;如果 %util 高且 r/w 频繁,就要往下查是哪个进程在驱动这些IO。
定位高IO消耗的进程
用 iotop -o(只显示正在做IO的进程),按I/O%列排序,一眼就能揪出“IO大户”。重点关注:
- 进程名是否合理(如 mysqld、rsync、java 应用、日志轮转脚本);
- 读写速率(B/s)是否异常(例如一个后台脚本持续写入200MB/s);
- 是否处于 D 状态(不可中断睡眠),这往往意味着它卡在底层IO上,需结合栈信息进一步分析。
确认PID后,别急着kill,先保留现场:记录时间点、命令行(ps -fp PID)、打开文件(下一步要用)。
标签: mysql linux java 硬盘 栈 ai ios
还木有评论哦,快来抢沙发吧~