1 个磁盘上有两个系统池 - 1 个或 2 个 /boot 目录和 WTB grub?

1 个磁盘上有两个系统池 - 1 个或 2 个 /boot 目录和 WTB grub?

我有一个遗留的 root-on-zfs 安装,曾经是通过在单独的 ext4 分区上安装到带有 /boot 的 ext4 / ,然后将 / 的内容移动到 ZFS 池来完成的。

我在同一个磁盘上安装了各种 *BSD,从未造成任何问题,但现在我正在考虑在未使用的分区上进行 Devuan 安装。更准确地说:将已设置的安装从另一台计算机(使用 XFS)复制到相关分区上的新池。

我想坚持在自己的分区上使用 /boot 的方法,并且我认为最好不要对两个发行版使用单个 /boot 。因此,有两个 /boot 分区。

我以前从未这样做过,即使等式中没有 ZFS 也没有这样做过。这将如何与 grub 一起工作,特别是。考虑到它们将是 2 个不同的版本,并且每个发行版在某个时候都会想要生成一个新的 grub 配置?它会根据内核(在引导上)与内核模块(在池上)的匹配来确定哪个引导分区与哪个池相匹配,还是我必须在每次 grub 更新后手动验证一致性(在 grub.cfg 中) ?我看到 grub.cfg 仅引用保存 /boot 的分区的 UUID,加上池的名称作为内核参数。

FWIW,这台机器确实有 UEFI 支持,但似乎没有给我一个启动 EFI 分区的选项(例如进入 rEFInd),可能是因为还安装了 grub 引导加载程序。

我不会遇到必须经过一些麻烦才能启动辅助发行版的问题。

答案1

事实证明这是可能的,但需要一些工作。

如果第二个 Linux 安装不共享相同的 /boot 目录(或分区),Grub 本身将不会检测到它。我记得这对于检测我在 Linux 安装旁边安装的 BSD 安装也是一个问题。

好消息是,这意味着 grub 可以在每次安装时运行,而不会弄乱其他安装,当然只要它不安装到 MBR 引导扇区即可。

棘手的部分是让 rEFInd 检测每个发行版可能安装的不同内核,并使用正确的参数启动选定的 initrd,以便它加载正确的 ZFS 池。我知道的针对 1 个发行版实现此目的的最简单方法是使用 grub 和ubuntu/grubx64.efi。事实证明,此加载程序将 grub.cfg 的路径硬编码;必须/EFI/ubuntu/grub.cfg如此,因此将其复制到其他目录不会像我希望的那样解决任何问题。幸运的是,Debian(以及 Devuan)有自己的加载程序版本,它需要 grub.cfg /EFI/debian/grub.cfg,所以这为我解决了这个问题。(注意:Devuan 版本创建了一个目录 /EFI/$HOSTNAME,所以我不得不重命名它。)

我的问题还没有完全解决。目前,我可以通过虚拟机启动第二次安装,并通过原始磁盘访问 EFI 分区以及该安装的 /boot 和 ZFS 池分区。我的笔记本电脑没有提供在启动时调出启动管理器的选项;它总是直接引导到我安装在 MBR 引导扇区上的 grub。我添加了一个 grub 节来查找并启动 EFI 分区上的 rEFInd,但这还不起作用 - 是否可以做到这一点?

相关内容