我使用以下命令创建了一个新的 md 数组:
mdadm --create /dev/md1 -l 1 -n 2 /dev/sd[ed]1
但现在/proc/mdstat
将数组显示为“自动只读”且 resync=PENDING:
~ # cat /proc/mdstat
Personalities : [raid1]
md1 : active (auto-read-only) raid1 sde1[1] sdd1[0]
976630336 blocks super 1.2 [2/2] [UU]
resync=PENDING
md0 : active raid1 sdb1[0] sdc1[1]
1953511936 blocks [2/2] [UU]
unused devices: <none>
根据这个网站我可以用以下方法解决这个问题:
mdadm --readwrite /dev/md1
这确实有效:
~ # mdadm --readwrite /dev/md1
~ # cat /proc/mdstat
Personalities : [raid1]
md1 : active raid1 sde1[1] sdd1[0]
976630336 blocks super 1.2 [2/2] [UU]
[>....................] resync = 0.0% (54400/976630336) finish=598.2min speed=27200K/sec
md0 : active raid1 sdb1[0] sdc1[1]
1953511936 blocks [2/2] [UU]
unused devices: <none>
但我仍然想知道这里发生了什么,但我找不到任何有关这方面的真实信息。有谁知道为什么数组默认为这种状态?
编辑:添加 dmesg 输出:
~ # grep kernel /var/log/syslog.1
Nov 13 10:03:44 iserv kernel: [160446.860113] e1000: eth1 NIC Link is Down
Nov 13 10:04:48 iserv kernel: [160511.017666] e1000: eth1 NIC Link is Up 1000 Mbps Full Duplex, Flow Control: RX/TX
Nov 13 20:12:40 iserv kernel: [196982.775186] sda: sda1
Nov 13 20:12:59 iserv kernel: [197001.598187] sdd: sdd1
Nov 13 20:13:13 iserv kernel: [197016.344939] sde: sde1
Nov 13 20:14:05 iserv kernel: [197067.520825] md: bind<sdd1>
Nov 13 20:14:05 iserv kernel: [197067.521263] md: bind<sde1>
Nov 13 20:14:05 iserv kernel: [197067.670215] md/raid1:md1: not clean -- starting background reconstruction
Nov 13 20:14:05 iserv kernel: [197067.670219] md/raid1:md1: active with 2 out of 2 mirrors
Nov 13 20:14:05 iserv kernel: [197067.670246] md1: detected capacity change from 0 to 1000069464064
Nov 13 20:14:05 iserv kernel: [197067.675101] md1: unknown partition table
Nov 13 20:24:10 iserv kernel: [197672.572128] md: md1 switched to read-write mode.
Nov 13 20:24:10 iserv kernel: [197672.572269] md: resync of RAID array md1
Nov 13 20:24:10 iserv kernel: [197672.572273] md: minimum _guaranteed_ speed: 1000 KB/sec/disk.
Nov 13 20:24:10 iserv kernel: [197672.572275] md: using maximum available idle IO bandwidth (but not more than 200000 KB/sec) for resync.
Nov 13 20:24:10 iserv kernel: [197672.572280] md: using 128k window, over a total of 976630336k.
答案1
当一个数组最初被组装时,它被置于“自动只读”模式。我用我的内核 (3.10.x) 和 mdadm (3.3) 进行了快速测试,创建时不会发生这种情况,但您必须运行不同的版本。
然而,自动只读并不是一个错误,也没有什么值得担心的。其背后的基本思想是让--assemble
(显然现在甚至--create
)更安全:在阵列进行读写之前,不会向磁盘写入任何内容。 (我不确定元数据是否仍在创建时写入。)
当数组收到第一次写入时,会自动从自动只读切换为读写。因此,如果您继续在设备上创建文件系统、LVM 物理卷或其他任何内容,它就会切换到读写状态,并开始同步。
您需要mdadm --readwrite
在其上运行的唯一原因是您希望它在执行任何写入之前同步。