【发布时间】:2015-05-03 10:46:48
【问题描述】:
我正在编写一个 Chef 配方,用于在现有系统上自动设置软件 RAID 1。基本流程是:
- 清除新磁盘上的分区表 (/dev/sdb)
- 添加新分区,然后使用 parted 设置为 raid(sdb1 用于 /boot,sdb2 使用 LVM 用于 /)
- 使用 mdadm --create ... 缺失的 /dev/sdb 创建降级 RAID
- pvcreate /dev/md1 && vgextend VolGroup /dev/md1
- pvmove /dev/sda2 /dev/md1
- vgreduce VolGroup /dev/sda2 && pvremove /dev/sda2
- ...
- ...
我坚持不。 5. 使用 2 个相同大小的磁盘,我总是会收到错误消息:
Insufficient free space: 10114 extents needed, but only 10106 available
Unable to allocate mirror extents for pvmove0.
Failed to convert pvmove LV to mirrored
我认为这是因为当我执行 mdadm --create 时,它会向磁盘添加额外的信息,因此它的物理范围会稍微少一些。
要解决此问题,通常会从实时发行版中重新启动系统,然后:
- e2fsck -f /dev/VolGroup/lv_root
- lvreduce -L -0.5G --resizefs ...
- pvresize --setphysicalvolumesize ...G /dev/sda2
- 等等等等
- 重启
然后继续步骤号。 5 以上。
我不能用 Chef 做到这一点,因为它无法处理重新启动到实时发行版并从中断处继续。我知道这显然不是幂等的。
所以我的要求是能够在不使用 live distro cd 的情况下(以某种方式)在 live 系统上进行 lvreduce。
有人对如何实现这一点有任何想法吗?
也许?:
- 以 root 身份挂载远程文件系统并将当前 root 重新挂载到别处
- 将根文件系统重新挂载为只读(但我不知道这怎么可能,因为您一开始就无法卸载活动系统)。
- 或其他解决方案以某种方式重新启动到实时发行版,编写调整大小脚本并重新启动并继续运行 Chef(不确定这是否可能
想法?
【问题讨论】:
标签: linux chef-infra partitioning mount