[译]badblocks指令

本文介绍了badblocks工具的使用方法及参数说明,该工具用于检测硬盘坏道,包括如何指定区块大小、检查次数等。此外还提供了示例命令,展示了如何利用badblocks配合fsck跳过已知坏道进行磁盘检测,以及如何在创建文件系统前检测坏道。
 原贴:http://www.linuxfly.org/post/192.htm

14

12月

[译]badblocks指令
| |
[2007/12/14 16:40 | 分类: 基础知识 » 系统命令 | by linuxing ]
   硬盘是一个损耗设备,当使用一段时间后可能会出现坏道等物理故障。电脑硬盘出现坏道后,如果不及时更换或进行技术处理,坏道就会越来越多,并会造成频繁死机和数据丢失。最好的处理方式是更换磁盘,但在临时的情况下,应及时屏蔽坏道部分的扇区,不要触动它们。badblocks就是一个检查坏道位置的工具。
一、命令参数
badblocks使用格式为:
引用
badblocks  [  -svwnf  ]  [  -b block-size ] [ -c blocks_at_once ] [ -i
      input_file ] [ -o output_file ] [ -p num_passes ] [ -t test_pattern  ]
      device [ last-block ] [ start-block ]

参数含义是:
引用
-b blocksize
 指定磁盘的区块大小,单位为字节,默认值为“block 4K ”(4K/block)
-c blocksize
 每个区块检查的次数,默认是16次
-f
 强制在一个已经挂载的设备上执行读写或非破坏性的写测试操作
 (我们建议先umount设备,然后再进行坏道检测。仅当/etc/mtab出现误报设备挂载错误的时候可以使用该选项)
-i file
 跳过已经显示在file文件中的坏道,而不进行检测(可以避免重复检测)
-o file
 把检测结果输出到file文件
-p number
 重复搜寻设备,直到在指定通过次数内都没有找到新的坏块位置,默认次数为0
-s
 在检查时显示进度
-t pattern
 通过按指定的模式读写来检测区块。你可以指定一个0到ULONG_MAX-1的十进制正值,或使用random(随机)。
 如果你指定多个模式,badblocks将使用第一个模式检测所有的区块,然后再使用下一个模式检测所有的区块。
 Read-only方式仅接受一个模式,它不能接受random模式的。
-v
 执行时显示详细的信息
-w
 对每个区块都先写入,然后再从它读取信息
[device]
 指定要检查的磁盘装置。
[last-block]
 指定磁盘装置的区块总数。
[start-block]
 指定要从哪个区块开始检查

二、示例
badblocks以4096的一个block,每一个block检查16次,将结果输出到“hda-badblocks-list”文件里

# badblocks -b 4096 -c 16 /dev/hda1 -o hda-badblocks-list

hda-badblocks-list”是个文本文件,内容如下:
引用
# cat hda-badblocks-list
51249
51250
51251
51253
51254
……
61245
……

可以针对可疑的区块多做几次操作。下面,badblocks以4096字节为一个“block”,每一个“block”检查1次, 将结果输出到“hda-badblocks-list.1”文件中,由第51000 block开始,到63000 block结束

# badblocks -b 4096 -c 1 /dev/hda1 -o hda-badblocks-list.1 63000 51000

这次花费的时间比较短,硬盘在指定的情况下在很短的时间就产生“嘎嘎嘎嘎”的响声。由于检查条件的不同,其输出的结果也不完全是相同的。重复几次同样的操作,因条件多少都有些不同,所以结果也有所不同。进行多次操作后,直到产生最后的hda-badblock-list.final文件。

三、其他
1、fsck使用badblocks的信息
badblocks只会在日志文件中标记出坏道的信息,但若希望在检测磁盘时也能跳过这些坏块不检测,可以使用fsck的-l参数:
# fsck.ext3 -l /tmp/hda-badblock-list.final /dev/hda1

2、在创建文件系统前检测坏道
badblocks可以随e2fsck和mke2fs的-c删除一起运行(对ext3文件系统也一样),在创建文件系统前就先检测坏道信息:

# mkfs.ext3 -c /dev/hda1

代码表示使用-c在创建文件系统前检查坏道的硬盘。
这个操作已经很清楚地告知我们可以采用“mkfs.ext3 -c”选项用“read-only”方式检查硬盘。这个命令会在格式化硬盘时检查硬盘,并标出错误的硬盘“block”。用这个方法格式化硬盘,需要有相当大的耐心,因为命令运行后,会一个个用读的方式检查硬盘。

四、参考资料
原文来自:
http://www.oreillynet.com/linux/cmd/cmd.csp?path=b/badblocks
参考:
http://tech.ccidnet.com/art/302/20031106/70263_1.html
Tags: fsck , badblocks
`badblocks` 是 Linux 系统中用于检测磁盘坏块的工具,通常用于检查硬盘或存储设备的物理损坏情况。它可以将检测到的坏块列表传递给 `e2fsck` 或 `mke2fs` 工具,以便在文件系统中将这些坏块标记为不可用,从而避免数据写入这些区域。 ### 基本使用方法 #### 1. 检查设备并列出坏块 要检查某个设备(例如 `/dev/sdb1`)是否存在坏块,可以使用以下命令: ```bash sudo badblocks -v /dev/sdb1 ``` - `-v`:启用详细模式,显示检测进度和结果。 该命令会扫描整个设备,并输出所有检测到的坏块编号。如果没有任何输出,则表示未发现坏块。 #### 2. 将坏块写入文件 可以将检测到的坏块列表保存到文件中,以便后续使用: ```bash sudo badblocks -v /dev/sdb1 > badblocks.txt ``` 此命令会将所有坏块编号写入 `badblocks.txt` 文件中。 #### 3. 与 `fsck` 结合使用 在检查文件系统时,可以将坏块文件传递给 `e2fsck`,使其跳过这些坏块: ```bash sudo e2fsck -l badblocks.txt /dev/sdb1 ``` - `-l`:指定坏块文件列表,`e2fsck` 会将这些块标记为不可用。 #### 4. 强制读写测试 如果希望进行更彻底的检查,可以使用 `-w` 选项进行写入测试: ```bash sudo badblocks -wsv /dev/sdb1 ``` - `-w`:执行写入模式,依次写入特定模式(0xaa、0x55、0xff、0x00)并验证读取结果。 - `-s`:显示进度条。 ⚠️ **注意**:写入模式会破坏设备上的所有数据,请确保设备上没有重要数据或已备份数据。 #### 5. 指定测试块大小 默认情况下,`badblocks` 使用 1024 字节的块大小。如果设备使用不同的块大小,可以使用 `-b` 指定: ```bash sudo badblocks -b 4096 -v /dev/sdb1 ``` - `-b 4096`:指定块大小为 4096 字节。 #### 6. 多线程检测 为了加快检测速度,可以使用 `-t` 指定多个线程进行并行检测: ```bash sudo badblocks -t 4 -v /dev/sdb1 ``` - `-t 4`:使用 4 个线程进行并行检测。 --- ### 示例流程:检测并标记坏块 1. **检测坏块并保存到文件**: ```bash sudo badblocks -v /dev/sdb1 > badblocks.txt ``` 2. **使用 `e2fsck` 标记坏块**: ```bash sudo e2fsck -l badblocks.txt /dev/sdb1 ``` 3. **重新检查文件系统**: ```bash sudo e2fsck -f /dev/sdb1 ``` --- ### 注意事项 - 在使用 `badblocks` 进行写入测试时,务必确保设备未挂载或没有重要数据。 - 对于 SSD 设备,频繁的写入测试可能会缩短其寿命,建议仅在必要时使用。 - 检测时间取决于设备大小和检测模式,可能需要数小时完成。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值