有一个通过mdadm( linux raid) 组装的软件 RAID5。并且需要用新磁盘替换其中一个仍然健康的阵列卷。这通常通过将旧磁盘标记为故障并添加具有阵列恢复功能的新磁盘来完成:
mdadm /dev/md0 -f /dev/sdd1
mdadm /dev/md0 -r /dev/sdd1
mdadm /dev/md0 --add /dev/sdc1
但是阵列重建需要相当长的时间,如果其他磁盘出现故障,就有可能丢失整个阵列。是否可以在添加新卷的同时以某种方式使用健康的旧卷,从而最大限度地降低阵列的风险?
根据对 的回答,该功能在 3.2 版(2012 年初发布)中
unix.SO被添加到 linux 内核中,相关选项出现在mdadm 3.3 版(2013 年发布)中。因此,如果您有足够的新鲜软件,那么您需要在阵列中添加一个新磁盘(它将添加为spare):并使用以下命令请求更换磁盘:
此命令将要求您将 sdd 替换为 sdc。该参数
with是可选的,如果不指定,则spare使用任何磁盘。执行此命令后,将开始向新磁盘写入数据的漫长过程,新卷同步后会自动替换旧卷。旧的 sdd 驱动器将被标记为故障,需要像往常一样从阵列中移除:
如果您只有一个合适的 3.2+ 内核,但是旧版本
mdadm- 那么您可以通过首先添加新磁盘直接通过sysfs伪系统执行相同的操作spare然后请求更换:
一般来说,这正是它所做
mdadm的,因为结果将是相同的:在新磁盘同步期间,旧磁盘将照常工作,然后它将变为failed.但是,如果核心较旧,那就很难过,并且很难提供独特的成功。
RAID4/5/6 和 RAID10 支持此方法。不支持 RAID1,原因很简单,在 RAID1 中使用更长的时间,您可以随时自由更改阵列中的磁盘数量。也就是不用更换一个磁盘,而是可以将阵列从两个磁盘扩展到三个,等待定期重建,移除旧磁盘,然后将阵列中的磁盘数量改回 2。这样,至少 2数据副本一直保存。
例如,如果您的 raid5 有三个磁盘,请尝试添加第四个,并同时重组到 raid6。由于 raid6 提供了两个故障磁盘的安全性,因此您可以放心地喝咖啡。添加一个备用驱动器到raid5:
在raid6中重组:
接下来,删除一个可疑驱动器:
回到 raid5 :
用于安全复制
/root/raid5backup小尺寸的文件必须物理上不在此数组中。