检测磁盘坏道并忽略方式挂载注意的细节

/dev/sda2? ? ? ? ? ? 591467212 237121952 323815736? 43% /
tmpfs? ? ? ? ? ? ? ? ? 4149320? ? ? ? ?0? ?4149320? ?0% /dev/shm
/dev/sda1? ? ? ? ? ? 117927380? ? ?11016 111829340? ?1% /boot

使用命令badblocks -s -v -o /root/sda1_blocks.txt /dev/sda可以检测/dev/sda1和/dev/sda2 坏道的信息,

但是根目录卸载不了,没办法同时卸载/dev/sda1和/dev/sda2之后重新挂载(忽略坏道的方式)。

如果这个时间执行e2fsck -l /root/sda1_blocks.txt /dev/sda1 会出现以下提示:

Bad block 126569731 out of range; ignored.

原因是badblocks -s -v目录记录下的坏道序号,都是从0开始,不是独占的。

所以需要只能单独对/dev/sda1进行检测及重新挂载,步骤如下:

badblocks -s -v -o /root/sda1_blocks.txt /dev/sda1
umount?/dev/sda1
e2fsck -l /root/sda1_blocks.txt?/dev/sda1
mount /dev/sda1 /boot

badblocks命令

badblock命令用于查找磁盘中损坏的区块。 硬盘是一个损耗设备,当使用一段时间后可能会出现坏道等物理故障。电脑硬盘出现坏道后,如果不及时更换或进行技术处理,坏道就会越来越多,并会造成频繁死机和数据丢失。最好的处理方式是更换磁盘,但在临时的情况下,应及时屏蔽坏道部分的扇区,不要触动它们。badblocks就是一个很好的检查坏道位置的工具。

语法

badblock (选项) (参数)

选项

  • -b<区块大小>:指定磁盘的区块大小,单位为字节;
  • -o<输出文件>:将检查的结果写入指定的输出文件;
  • -s:在检查时显示进度;
  • -v:执行时显示详细的信息;
  • -w:在检查时,执行写入测试。

参数

  • 磁盘装置:指定要检查的磁盘装置;
  • 磁盘区块数:指定磁盘装置的区块总数;
  • 启始区块:指定要从哪个区块开始检查。

实例

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文件。

e2fsck命令

e2fsck命令用于检查第二扩展文件系统的完整性,通过适当的选项可以尝试修复出现的错误。

e2fsck执行后的传回值及代表意义如下:

  • 0 没有任何错误发生。
  • 1 文件系统发生错误,并且已经修正。
  • 2 文件系统发生错误,并且已经修正。
  • 4 文件系统发生错误,但没有修正。
  • 8 运作时发生错误。
  • 16 使用的语法发生错误。
  • 128 共享的函数库发生错误。

语法

e2fsck(选项)(参数)

选项

  • -a:不询问使用者意见,便自动修复文件系统;
  • -b<superblock>:指定superblock,而不使用预设的superblock;
  • -B<区块大小>:指定区块的大小,单位为字节;
  • -c:一并执行badblocks,以标示损坏的区块;
  • -C:将检查过程的信息完整记录在file descriptor中,使得整个检查过程都能完整监控;
  • -d:显示排错信息;
  • -f:即使文件系统没有错误迹象,仍强制地检查正确性;
  • -F:执行前先清除设备的缓冲区;
  • -l<文件>:将文件中指定的区块加到损坏区块列表;
  • -L<文件>:先清除损坏区块列表,再将文件中指定的区块加到损坏区块列表。因此损坏区块列表的区块跟文件中指定的区块是一样的;
  • -n:以只读模式开启文件系统,并采取非互动方式执行,所有的问题对话均设置以"no"回答;
  • -p:不询问使用者意见,便自动修复文件系统;
  • -r:此参数只为了兼容性而存在,并无实际作用;
  • -s:如果文件系统的字节顺序不适当,就交换字节顺序,否则不做任何动作;
  • -S:不管文件系统的字节顺序,一律交换字节顺序;
  • -t:显示时间信息;
  • -v:执行时显示详细的信息;
  • -V:显示版本信息;
  • -y:采取非互动方式执行,所有的问题均设置以"yes"回答。

参数

文件系统或者分区:指定文件系统或者分区所对应的设备文件名。

实例

检查/dev/sda1是否有问题,如发现问题便自动修复:

e2fsck -a -y /dev/sda1

执行e2fsck或fsck前请先umount partition,否则有机会令档案系统毁损。如果需要对根目录/进行检查及修复,便需要进入singal user mode执行。

原文地址:http://blog.51cto.com/moerjinrong/2343470

时间: 2024-11-10 01:35:34

检测磁盘坏道并忽略方式挂载注意的细节的相关文章

怎么用HD Tune检测硬盘坏道

HD Tune软件不仅小巧而且很易使用,是一款检测电脑硬盘的优良工具.不仅是电脑硬盘,包括移动硬盘在内一样可以检测.那么,如何使用HD Tune呢?如何使用HD Tune检测磁盘坏道呢? 工具/原料 HD Tune软件一枚 使用HD Tune检查硬盘坏道 1.百度搜索下载HD Tune软件,注意:尽量选择系统之家官网上下载这类软件,因为系统之家上的软件不会捆绑的流氓软件 2.软件打开之后,界面如图,最上方显示硬盘的厂家信息,图示红色遮挡区 3.点击选项卡切换至错误扫描,如图,然后在红框位置,尽量

Linux 磁盘坏道检测和修复

使用dmesg检查是否有关于磁盘错误的信息,果不其然发现大量磁盘扇区错误的信息,如下: end_request: I/O error, dev 03:06 (sda), sector 从上面的输出我们判定扇区可能出现了问题,使用badblocks -s -v -o /root/badblocks.log /dev/sda 检查硬盘是否产生坏道并输出到badblocks.log中.log大约是这样的模式:64039224 64039240 64039241 64039242 64039243 64

&nbsp; 磁盘坏道检查

当磁盘出现以下现象时,有可能是磁盘出现坏道需要进行检查和修复 1.    读取磁盘中的数据时,磁盘设备发出异常声响 2.    访问磁盘中的某个文件时,反复读取且出错,提示文件损坏 3.    对于新建立的分区无法完成格式化 4.    系统使用该磁盘时频繁死机 硬盘出现坏道后,检测磁盘的坏道情况可以使用badblocks命令,结合"-s"选项用于显示进度信息,"-v"选项用于显示详情,列如:执行以下操作可以查看硬盘设备/dev/sdb中德坏道情况 Badblock

centos出现磁盘坏道,怎么检索和修复

故障现象,在/var/log/message这个目录中出现下面的error: [24934098.161918] Buffer I/O error on device sdaj, logical block 4 [24934098.161921] Buffer I/O error on device sdaj, logical block 5 [24934098.161922] Buffer I/O error on device sdaj, logical block 6 [24934098.

检测raid类型和磁盘坏道脚本

#!/bin/sh #脚本功能: #安装工具MegaCli64 #Host Information:主机名和ip地址 #Raid Information:raid信息和充电状态 #WARNING Information:MediaErrcount检测坏块和哪块盘 #Disk Information:磁盘信息 #上传MegaCli压缩包到opt目录下 Megdir=/opt/MegaRAID/MegaCli/ cd /opt if [ ! -d $Megdir ];then unzip MegaC

Linux上检测硬盘上的坏道和坏块

                            Linux上检测硬盘上的坏道和坏块 让我们从坏道和坏块的定义开始说起,它们是一块磁盘或闪存上不再能够被读写的部分,一般是由于磁盘表面特定的物理损坏或闪存晶体管失效导致的. 磁盘坏道分为三种: 0磁道坏道,逻辑坏道,硬盘坏道. 其中逻辑坏道可以使用上面的方法修复,0磁道坏道的修复方法是隔离0磁道,使用fdsk划分区的时候从1磁道开始划分区.如果是硬盘坏道的话,只能隔离不能修复.硬盘坏道的监测方法:使用上述方法检测修复后,再使用badblock

centos出现磁盘坏掉,怎么修复和检测。

当dmesg的时候,出现下面的信息说明磁盘有问题 Info fld=0x139066d0 end_request: I/O error, dev sda, sector 328230608 Buffer I/O error on device sda, logical block 41028826 sd 0:0:0:0: SCSI error: return code = 0x08000002 sda: Current: sense key: Medium Error Add. Sense: U

linux服务器磁盘坏道的发现及解决全过程

服务器的磁盘也没有做监控,其实我也不知道如何对磁盘的状态做监控,突然查看不到新数据,上去看了一下磁盘的情况,发现磁盘出现只读的情况,无法写入数据,要是大家谁知道怎么可以监控磁盘只读的方法,可以告诉我下,来个高达上一些的. 一.处理过程 1.磁盘坏道检查 出现问题之后,首先把业务停掉了,然后把磁盘卸载掉来进行修复,出现这种问题有可能是磁盘的磁道有坏区,我首先检查了一下磁盘坏道的情况. badblocks -sv /dev/sdb 差不多检查了一些时间,发现并没有坏道. 2.修复磁盘文件系统 在修复

badblocks坏道检测

linux下badblocks的使用: [[email protected] ~]# badblocks -h badblocks:选项需要一个参数 -- h Usage: badblocks [-b block_size] [-i input_file] [-o output_file] [-svwnf] [-c blocks_at_once] [-d delay_factor_between_reads] [-e max_bad_blocks] [-p num_passes] [-t tes