我在/var/log/kern.log中收到了指示驱动器故障的消息.在驱动器(ext4 – > ext3)之间复制$HOME时发生的消息:
[ 5733.186033] sd 4:0:0:0: [sdb] Unhandled sense code [ 5733.186038] sd 4:0:0:0: [sdb] Result: hostbyte=invalid driverbyte=DRIVER_SENSE [ 5733.186042] sd 4:0:0:0: [sdb] Sense Key : Medium Error [current] [ 5733.186048] sd 4:0:0:0: [sdb] Add. Sense: Unrecovered read error [ 5733.186053] sd 4:0:0:0: [sdb] CDB: Read(10): 28 00 05 b7 2e 40 00 00 08 00 [ 5733.186064] end_request: critical target error,dev sdb,sector 95891008
这些消息是散装的,这是其中一种. sdb是源驱动器.
如何找出该扇区属于哪个文件/ inode?我只是想知道,所以我可以从备份中恢复有问题的文件.比以下代码更快的速度加上后续的输出分析?
find . -type f -print \ -exec cp \{\} /dev/null \; \ -exec tail -n 1 /var/log/kern.log \;
操作系统:Ubuntu Oneiric.
编辑:上面的命令还向stderr输出无法读取的文件.
解决方法
粗略的想法是
>做一些计算,根据物理扇区号找出filesytem的块号
>使用debugfs testb / ncheck / icheck命令查明块是否正在使用以及正在使用它的文件的名称
有一个bad block HOWTO over at the smartmontools project site更详细地描述了该过程.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。