登录
首页 >  文章 >  linux

Linux磁盘坏道检测方法全解析

时间:2026-05-10 09:19:42 159浏览 收藏

推广推荐
下载万磁搜索绿色版 ➜
支持 PC / 移动端,安全直达
本文深入解析了Linux下使用badblocks工具检测磁盘坏道的完整流程与关键避坑要点:强调badblocks仅能检测和标记坏道而无法修复,真正规避坏道需配合e2fsck或mkfs等文件系统工具;明确指出检测前必须卸载设备(系统盘需借助Live环境),警示SSD用户慎用破坏性写入测试(-w参数),详解4K扇区硬盘必须指定-b 4096参数以避免误报漏报,并揭示坏块结果文件需通过e2fsck -l精准导入才能生效——同时提醒读者,坏道检测应作为SMART告警或I/O错误后的针对性诊断手段,而非日常例行操作。

Linux怎么查看磁盘坏道 Linux下badblocks扫描与修复详解

badblocks 不能直接“修复”坏道,它只负责检测和标记;真要让系统避开坏道,得靠 e2fsck 或 mkfs 配合使用。

badblocks 检测前必须卸载设备

只要目标设备(比如 /dev/sda1)还挂载着,badblocks 就会拒绝执行写入类测试,读取测试也可能因缓存干扰而漏检。强行运行常报错:Device or resource busy。这不是权限问题,是内核级保护机制。

正确做法是:

  • mount | grep sda1 确认是否已挂载
  • 若已挂载,先执行 sudo umount /dev/sda1
  • 系统盘无法卸载?得进 Live CD/USB 环境再操作
  • SSD 用户注意:-w 模式对 NAND 寿命有损耗,非必要不建议在生产 SSD 上跑

别乱用 -w 参数:写入测试 = 数据清零

badblocks -w 会向每个扇区写入特定模式(如 0x00、0xff),再读回校验。这个过程会覆盖原有数据,且不可逆。哪怕你只扫了部分区域,被扫到的块上所有文件都会损坏。

安全优先的检测顺序应该是:

  • 先跑一次只读检测:sudo badblocks -v -s /dev/sda1
  • 如果有输出(即发现坏块编号),再决定是否用 -w 强制触发硬盘重映射
  • -w 前必须确认:该分区无重要数据,或已完整备份
  • 现代硬盘的 G-List 重映射通常在写入时自动触发,-w 是模拟这个动作,不是“修好”物理损伤

结果文件怎么用:e2fsck -l 才是关键一步

badblocks 自己不会让文件系统避开坏道,它只是把坏块编号写进一个文本文件(比如 badsectors.txt)。真正起作用的是后续的 e2fsck 命令。

假设你已生成坏块列表:

sudo badblocks -v -o badsectors.txt /dev/sda1

接下来必须执行:

sudo e2fsck -l badsectors.txt /dev/sda1

注意两点:

  • e2fsck 要求设备处于未挂载状态,否则报错 The filesystem is mounted
  • -l 是小写 L,不是数字 1;输错参数会导致静默失败,坏块照常被使用
  • 如果文件系统是 XFS/Btrfs,e2fsck 不适用,得换对应工具(如 xfs_repair 不支持坏块列表导入)

4K 扇区硬盘必须加 -b 4096

现在绝大多数新机械盘和 NVMe SSD 的物理扇区大小是 4096 字节,但系统默认仍按 512 字节处理。如果不指定 -b 4096badblocks 会把一个物理扇区切成 8 个逻辑块来测,导致误报或漏报。

验证方法:

sudo fdisk -l /dev/sda | grep "Sector size"

输出类似 Sector size (logical/physical): 512 bytes / 4096 bytes 就说明要用 -b 4096

常用组合命令示例:

sudo badblocks -v -b 4096 -s -o badsectors.txt /dev/sda1

这个命令既匹配物理层,又留出人工复核空间——输出文件里每行一个十进制块号,可直接喂给 e2fsck -l

真正容易被忽略的点是:坏道检测不是一劳永逸的事。SMART 告警、I/O 错误日志、dmesg | grep -i "ata\|nvme\|error" 这些信号比定期扫盘更早预警。把 badblocks 当成确诊手段,而不是体检常规项。

今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>