CentOS下badblocks指令的详解

  CentOS下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”文件里

  ?


1

# 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结束

  ?


1

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

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

  三、其他

  1、fsck使用badblocks的信息

  badblocks只会在日志文件中标记出坏道的信息,但若希望在检测磁盘时也能跳过这些坏块不检测,可以使用fsck的-l参数:

  ?


1

# fsck.ext3 -l /tmp/hda-badblock-list.final /dev/hda1

  2、在创建文件系统前检测坏道

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

  ?


1

# mkfs.ext3 -c /dev/hda1

  代码表示使用-c在创建文件系统前检查坏道的硬盘。

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

(0)

相关推荐

  • CentOS下TCP断线监测详解

    TCP正常的断开,通信双方(服务端和客户端)都是能知道的.但是非正常的断开,比如直接拔掉了网线,就只能靠如下两种方法,实现短时间内的检测. 一,心跳包机制 心跳包机制,是网游设计中的常用机制.从用户层 ...

  • CentOS下ACL权限控制详解

    ACL权限控制 设置ACL权限:setfacl 查看ACL权限:getfacl ACL权限控制主要目的是提供传统的owner,group,other的read,wirte,execute权限之外的具体 ...

  • Centos下mail命令使用详解

    Centos下mail命令使用详解

  • CentOS下如何安装CodeBlocks?CentOS下安装CodeBlocks图文详解

    一. 安装平台说明: CentOs6.4-i686 gcc-4.4.7 二. 下载最新源码: 在此安装的是最新版:Code::Blocks 16.01 三. 阅读官方安装说明文档: 通过阅读官方安装说 ...

  • CentOS下管理日志服务详解

    Linux服务器一般都是被放置在机房中自动运行,管理员要了解服务器或是应用程序的运行状态,大都需要通过日志.日志文件用于记录Linux系统中各种运行消息,不同的日志文件记载了不同类型的信息,例如Lin ...

  • CentOS下千兆网卡带宽测试详解

    iperf 是一个基于C/S模型的纯带宽测试软件,可以测试网卡的吞吐量. iperf的好处是纯粹发包和接收,防止硬盘拖后腿,影响测试结果. 本文以千兆网卡Bcom 5720 进行测试,环境CentOS ...

  • CentOS下程序内存空间分配详解

    先来看一段简单代码: [cpp] view plaincopy在CODE上查看代码片派生到我的代码片 #include <stdio.h> #include <unistd.h> ...

  • CentOS 7下systemd管理的详解

    CentOS 7下systemd管理的详解 CentOS系统启动流程: POST --> Boot Sequence --> Bootloader --> kernel + init ...

  • CentOS启动和停止服务详解

    CentOS启动和停止服务详解 服务简介 Linux 系统服务是在Linux启 动时自动加载,并在Linux退出时自动停止的系统任务.在Linux 启动过程中,我们可以看得很多"starti ...