我正在尝试从降级的 RAID 阵列中恢复。我愚蠢地使用了mdadm --create
某些方法,现在我的几个设备有错误的超级块。幸运的是,我保留了旧超级块的副本:
/dev/sdd1:
Magic : a92b4efc
Version : 1.2
Feature Map : 0x0
Array UUID : 7318877d:a7538da2:dbdff5e9:613cc676
Name : vern:2
Creation Time : Thu Oct 20 21:58:58 2011
Raid Level : raid5
Raid Devices : 3
Avail Dev Size : 1953517954 (931.51 GiB 1000.20 GB)
Array Size : 1953517568 (1863.02 GiB 2000.40 GB)
Used Dev Size : 1953517568 (931.51 GiB 1000.20 GB)
Data Offset : 2048 sectors
Super Offset : 8 sectors
State : clean
Device UUID : 3dc62a0d:71ad83cf:f0dea827:6919f67c
Update Time : Mon Mar 4 19:53:30 2013
Checksum : a1b473f6 - correct
Events : 152880
Layout : left-symmetric
Chunk Size : 512K
将其与新的超级块进行比较:
Magic : a92b4efc
Version : 1.2
Feature Map : 0x0
Array UUID : 53e45e96:bc283e07:77748762:24fade80
Name : Velma:2 (local to host Velma)
Creation Time : Fri May 3 17:35:48 2013
Raid Level : raid5
Raid Devices : 3
Avail Dev Size : 1953257858 (931.39 GiB 1000.07 GB)
Array Size : 1953257472 (1862.77 GiB 2000.14 GB)
Used Dev Size : 1953257472 (931.39 GiB 1000.07 GB)
Data Offset : 262144 sectors
Super Offset : 8 sectors
State : clean
Device UUID : bae87034:ba42a7ed:c4fa2854:5888d619
Update Time : Fri May 3 17:35:48 2013
Checksum : b3c99dd4 - correct
Events : 0
Layout : left-symmetric
Chunk Size : 512K
这里的主要区别在于数据偏移。如果我可以手动将数据偏移设置回 2048 个扇区,那么我就有机会恢复 RAID 卷中的数据。
那么...我该如何设置这个偏移量?
答案1
我在内心深处找到了答案http://comments.gmane.org/gmane.linux.raid/38674:事实证明,有一个分支mdadm
允许自定义数据偏移。获取它的方法如下:
git clone -b data_offset git://neil.brown.name/mdadm
cd mdadm
make
这增加了根据每个设备设置数据偏移量的功能,方法是在设备 ID 后附加 : 和偏移量。例如:
./mdadm --create /dev/md2 --level=5 -raid-devices=3 --assume-clean \
/dev/sdb3:89088 /dev/sdd1:1024 /dev/sdc3:131072
我必须将偏移量除以 2,因为它是以 K 为单位,而不是以扇区为单位。我认为我可以使用
./mdadm --create /dev/md2 --level=5 -raid-devices=3 --assume-clean \
/dev/sdb3:178176s /dev/sdd1:2048s /dev/sdc3:262144s
但我还没有证实这一点。
无论如何,这构建了具有正确大小的数组,并且我已设法从中恢复了一些数据。结果!