新的 md 数组是自动只读的并且具有 resync=PENDING

新的 md 数组是自动只读的并且具有 resync=PENDING

我使用以下命令创建了一个新的 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在其上运行的唯一原因是您希望它在执行任何写入之前同步。

相关内容