首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在linux/unix中进行数据清理(即大容量存储位腐烂缓解)?

如何在linux/unix中进行数据清理(即大容量存储位腐烂缓解)?
EN

Unix & Linux用户
提问于 2015-09-07 13:10:10
回答 1查看 484关注 0票数 2

数据清洗是作为一种方法向我介绍的,它可以减少所谓的比特腐烂(在海量存储上)。

其基本原理是,硬盘上的数据可能“衰变”/“腐烂”,从而损坏,为了防止硬盘生产者,让磁盘内部为每个块写入添加一些额外的校正数据。当数据及其相应的校正/保护数据(某种纠错代码ECC)无法更正驱动器上的数据时,就会发生位腐烂。

现在,我的理解/信息是,随着时间的推移,数据(及其添加的更正信息)逐渐丢失。这意味着等待的时间越长,内部就会发生更多的比特腐烂,直到到达一个不可能纠正的点(即内部添加的校正数据,不再提供足够的修复信息)。

数据清理似乎有助于减轻比特的腐烂。我认为这是理想的内部读取驱动器的所有数据和检查数据与额外的纠错数据。如果当测试驱动器遇到问题时,它可以纠正错误。此外,所有内部的位腐字节(还没有真正的URE)可以设置回I一个更好的状态。

尽管如此,我如何触发设备来进行这样的数据清理呢?

smartctl还是hdparm

smartctl有三种类型的测试:conveyenceshortlong/extended。对我来说真正有意义的是long,因为读取驱动器的所有数据显然需要时间来实现潜在的修复。

针对这里发现的RAID 1的一个问题:基于mdadm的位腐检测与校正

我想知道如何做,当没有RAID在那里,只是一个普通的SATA驱动器。

EN

回答 1

Unix & Linux用户

发布于 2021-01-25 15:31:33

阅读整个平原驱动器:

代码语言:javascript
运行
复制
dd if=/dev/sd(x) of=/dev/null iflag=nocache status=progress

可能有助于判断错误。

badblocks(8) with -n选项是最近的。先卸载驱动器。

票数 0
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://unix.stackexchange.com/questions/228051

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档