我有一个遗留的 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 引导加载程序。
我不会遇到必须经过一些麻烦才能启动辅助发行版的问题。
事实证明这是可能的,但需要一些工作。
如果第二个 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,但这还不起作用 - 是否可以做到这一点?