我收集了一些旧的 3.5" 软盘,希望从中恢复尽可能多的数据。
问题是由于一些文件的结构,我需要维护所有文件的长度,这意味着应该填充任何坏扇区(tl;dr 原因是有些文件是 Acorn ADFS 文件,其中数据和代码是组合。代码将数据引用为从文件开始的偏移量。读取 ADFS 格式在 linux 中不是问题,坏扇区的填充是)。
这些光盘已经 25 年没有被读取过,所以我预计会出现不可预测的读取、经常出现坏扇区并可能导致磁盘无法读取——只要数据恢复最大化,我并不介意。
为此,我希望需要多次通过才能尽可能多地阅读。
dd
我查看了 dd,这个命令有望首次运行:
dd if=/dev/fd0 of=adfs.img conv=noerror,sync
随后调用
dd if=/dev/fd0 of=adfs.img conv=noerror,notrunc
在哪里:
noerror表示忽略错误
sync表示坏扇区用空字符填充
notrunc表示调用 dd 时不会截断(已经存在的)输出文件。
然而,当我阅读手册页和notrunc 的解释时,尽管设置了 notrunc,dd 每次都会覆盖输出,导致输出仍然只代表上次读取的内容。之前读取正确但现在损坏的任何扇区(例如由于旧软盘性能下降)将被空值覆盖。
所以dd看起来不合适。
救援
ddrescue看起来很有前途,因为只要使用日志文件记录成功写入的内容,然后在下一次完成时引用它,它就可以与多次传递一起使用。
第一遍只读取非错误块
ddrescue -d -p --no-scrape /dev/fd0 output.img log/output.logfile
第一次通过和随后的通过以填补错误
ddrescue -d -r3 /dev/fd0 output.img log/output.logfile
在哪里
-d直接磁盘访问。忽略系统缓存
--no-scrape或-n跳过抓取阶段
-p preallocate 在恢复之前预分配磁盘空间,即输出文件将与输入文件/设备大小相同
-r3重试坏扇区 3 次(在第二遍之后使用)
但陷阱是 ddrescue 似乎不会在坏扇区出现时对其进行填充。使用 -p 设置,它似乎会导致文件末尾的所有填充,而不是根据需要维护文件开头的数据偏移量。
这似乎是因为 ddrescue 是为了尽量节省磁盘空间而编写的,因此坏扇区被截断,如果坏扇区在后续通道中被成功读取,则添加到。设置 -p 只是创建一个与输入文件大小相同的输出文件以节省空间,而不是填充数据。因此,设置或取消设置 -p 的输出内容将是相同的,即直到文件末尾才被填充。
问题
所以我的问题是三方
即使设置了 -p,ddrescue 也不会填充恢复的文件是否正确?
有什么办法让它垫起来吗?在我的互联网搜索中,我读到一条评论(会再次找到并添加),脚本可以使用 ddrescue 创建的日志文件来填充相关位置。知道怎么做吗?
和
- 你知道有什么更好的命令/程序/脚本来做我想做的事——通过多次读取损坏的磁盘并填充坏扇区来最大程度地恢复数据吗?
我使用的是 Ubuntu 18.04,dd 版本是 (coreutils) 8.28,GNU ddrescue 版本是 1.22,两者都来自 Ubuntu 存储库。
一如既往地感谢您的帮助
GNU ddrescue是您尝试恢复的正确工具。
这种推定是不正确的。 您可能会对手册这样说感到困惑:
这只是意味着没有写入零来代替坏扇区。那些坏扇区应该是什么都没有被填充。如果你正在写入空白磁盘或文件,目标未写入的区域将读回为零(空字节)。
此外,
-p
/--preallocate
选项与“填充”没有任何关系。这意味着“预分配”。在支持的文件系统上,该选项可确保您在目标上有足够的磁盘空间来存储源磁盘。GNU ddrescue 输出的文件在逻辑上与源磁盘的布局相同。 从源读取的块进入目标中的相同位置。您甚至可以反转整个恢复 (
-R
/--reverse
) 并且块将向后填充,仍然在正确的位置。GNU ddrescue 做的正是你想要的。它可以进行多次传递 (
-r
/ ),所需的坏扇区“填充”是 GNU ddrescue 的默认行为。从手册:--retry-passes=n
为了完全清楚并解决您的担忧,即成功读取之后是错误读取会被空“填充”,ddrescue 不会尝试重新读取成功的读取——没有必要,因为数据已经恢复. 映射文件是 ddrescue 知道它已经恢复和恢复失败的方式。