在实时挂载系统上调整根分区大小的解决方案

Solutions to resize root partition on live mounted system

我正在编写一个 Chef 配方以在现有系统上自动设置软件 RAID 1。基本程序是:

  1. 清除新磁盘上的分区 table (/dev/sdb)
  2. 添加新分区,然后使用 parted 设置为 raid(sdb1 用于 /boot,sdb2 用于 LVM /)
  3. 使用 mdadm --create ... missing
  4. 创建降级的 RAID /dev/sdb
  5. pvcreate /dev/md1 && vgextend VolGroup /dev/md1
  6. pvmove /dev/sda2 /dev/md1
  7. vgreduce VolGroup /dev/sda2 && pvremove /dev/sda2
  8. ...
  9. ...

我坚持不。 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 时,它​​向磁盘添加了额外的信息,因此它的物理范围略小。

要解决此问题,通常会从实时发行版重新启动系统,并且:

并继续第 1 步。 5 以上。

我不能用 Chef 做到这一点,因为它无法处理重新启动到实时发行版并从中断的地方继续。我知道这显然不是幂等的。

所以我的要求是能够在不使用实时发行版 CD 的情况下在实时系统上进行 lvreduce(以某种方式)。

有人对如何实现这一目标有任何想法吗?

也许吧?:

想法?

我不确定 chef 是否是合适的工具。

不是确定的解决方案,但我会为这种情况做些什么:

  1. 用厨师和食谱创建实时系统
  2. 在此启动
  3. 运行 厨师作为厨师独奏,使用食谱进行工作(这应该可以工作,因为首先卸载了物理磁盘)

最好的方法是编写说明书,以便能够从头开始重做目标框,一旦完成,您可以在系统安装时使用正确的分区完全重新安装目标,然后让厨师重建您的应用程序堆栈.