简而言之:我正在运行从 5 个磁盘的 RAID5 到 6 个磁盘的 RAID6 的重塑,需要停止,以便我可以关闭系统。我不在乎重塑是否需要在重新启动后重新开始,但我希望保持数据完好无损。
时间越长:
系统:Synology DiskStation 1819+ 配备 DSM 6.2.2-24922
运行命令: /sbin/mdadm --grow /dev/md2 --force -l 6 -n 6 --backup-file=/etc/raid/bkp_reshape/md2_20190724_170727
(通过 GUI 启动,备份文件位置在 md0 上)
备份:可用,即使不是全部。
当我开始操作时,我打算运行几天,但是速度太慢了,预计时间超过了 40 天,我无法满足这个要求,因为我正在搬家,而且 DS 最迟需要在周一关闭。
以下是一些控制台输出:
# uname -a
Linux xxxx 4.4.59+ #24922 SMP PREEMPT Fri May 10 02:49:58 CST 2019 x86_64 GNU/Linux synology_denverton_1819+
# mdadm --version
mdadm - v3.4 - 28th January 2016
# cat /proc/mdstat
Personalities : [linear] [raid0] [raid1] [raid10] [raid6] [raid5] [raid4]
md2 : active raid6 sdf3[5] sda3[0] sde3[4] sdd3[3] sdc3[2] sdb3[1]
46856253440 blocks super 1.2 level 6, 64k chunk, algorithm 18 [6/5] [UUUUU_]
[>....................] reshape = 3.7% (439918592/11714063360) finish=111378.6min speed=1686K/sec
md1 : active raid1 sdf2[5] sda2[0] sdb2[1] sdc2[2] sdd2[3] sde2[4]
2097088 blocks [8/6] [UUUUUU__]
md0 : active raid1 sdf1[5] sda1[0] sdb1[1] sdc1[2] sdd1[3] sde1[4]
2490176 blocks [8/6] [UUUUUU__]
unused devices: <none>
# mdadm --detail /dev/md2
/dev/md2:
Version : 1.2
Creation Time : Mon Jun 10 12:16:53 2019
Raid Level : raid6
Array Size : 46856253440 (44685.61 GiB 47980.80 GB)
Used Dev Size : 11714063360 (11171.40 GiB 11995.20 GB)
Raid Devices : 6
Total Devices : 6
Persistence : Superblock is persistent
Update Time : Fri Jul 26 09:39:20 2019
State : clean, degraded, reshaping
Active Devices : 5
Working Devices : 6
Failed Devices : 0
Spare Devices : 1
Layout : left-symmetric-6
Chunk Size : 64K
Reshape Status : 3% complete
New Layout : left-symmetric
Name : xxxx:2 (local to host xxxx)
UUID : b6f288df:931fae61:03ecf298:60352fb4
Events : 754587
Number Major Minor RaidDevice State
0 8 3 0 active sync /dev/sda3
1 8 19 1 active sync /dev/sdb3
2 8 35 2 active sync /dev/sdc3
3 8 51 3 active sync /dev/sdd3
4 8 67 4 active sync /dev/sde3
5 8 83 5 spare rebuilding /dev/sdf3
当然,我已经查看过周围,并且发现了这一点:
echo frozen > /sys/block/md2/md/sync_action
停止/暂停操作
echo idle > /sys/block/md2/md/sync_action
或者
echo reshape > /sys/block/md2/md/sync_action
恢复
我不知道的是这是否真的适用于重塑,而不仅仅是(重新)同步。
在我不得不强制关机之前,任何帮助都将不胜感激。
谢谢!
编辑1
好的,这对我有用:
echo frozen > /sys/block/md2/md/sync_action
停止了 mdadm 进程- 发出
echo idle > /sys/block/md2/md/sync_action
导致 sync_action 立即切换到重塑,但 mdadm 进程没有重新启动 - 然后我重新启动,系统恢复后,重塑过程从中断的地方继续进行。其他一切看起来都很好。
编辑2
今天,经过48天的运行(加上我搬家前的几天),整个过程成功完成。