linux中识别 SSD/HDD 应以 /sys/block/*/queue/rotational 值为准(0 为 SSD,1 为 HDD),据此选择 I / O 调度器(SSD 用 none/noop,HDD 用 deadline/bfq),并启用 TRIM、1MiB 对齐及 noatime 等挂载优化,最后通过iostat、fio 验证效果。

linux 系统 中区分 SSD 和 HDD,关键看内核识别的底层特性,而非设备名称或型号。性能优化 必须基于准确识别,否则调度器、挂载参数等调整可能适得其反。
一、准确识别 SSD 还是 HDD
最可靠的方式是检查 /sys/block/*/queue/rotational 文件内容:
- 值为0 → 内核认定为 SSD(非旋转介质)
- 值为1 → 内核认定为 HDD(旋转介质)
例如查看 sda:cat /sys/block/sda/queue/rotational
注意:NVMe 设备(如 nvme0n1)默认为 0,但部分老旧驱动或 虚拟环境 可能误报,建议结合 lsblk -d -o NAME,ROTA,TYPE 综合判断。
二、I/ O 调度器选择原则
调度器需匹配物理介质特性:
- SSD(含 NVMe):优先用
none(5.0+ 内核)或noop;较新内核支持多队列,mq-deadline或kyber也可作为备选,但避免使用cfq或bfq - HDD:推荐
deadline或bfq(尤其在多任务混合负载下),cfq已弃用
临时切换(以 sda 为例):echo deadline > /sys/block/sda/queue/scheduler
永久生效需写入 /etc/default/grub 中的GRUB_CMDLINE_LINUX,添加elevator=deadline(HDD)或elevator=noop(SSD)。
三、SSD 专用优化项
识别为 SSD 后,应启用以下关键配置:
- 启用 TRIM:确保
fstrim定期运行(systemd 有fstrim.timer,默认启用);挂载时加discard参数(仅适用于轻负载,生产环境建议用定时 fstrim) - 分区对齐 :创建分区时使用
parted并指定unit MiB,起始扇区设为 2048(即 1MiB 对齐),避免跨页写入损耗 - 挂载参数优化:ext4 推荐
noatime,discard,commit=60;XFS 推荐noatime,logbufs=8,logbsize=256k
四、验证与持续观察
优化不是一次设置就结束,需结合实际负载验证效果:
- 用
iostat -x 1观察%util、await、r/s、w/s,SSD 的await通常远低于 10ms - 对比不同调度器下
fio随机读写 QD32 延迟分布(如 p99 - 检查
dmesg | grep -i "ssd|nvme|rotational"确认内核识别无误
不复杂但容易忽略。识别准、调度对、TRIM 开、对齐好——这四步到位,SSD 才能真正释放低延迟高 IOPS 的潜力。