Grub2 + 环回 + LVM

Grub2 + 环回 + LVM

我希望从环回文件托管的 LVM 分区引导我的系统,其中引导位于 USB 驱动器上。

使用非 LVM 设置和 ext4 环回文件,它可以正常启动(网上有一些指南),但我需要更多...我需要 LVM!

我的分区布局是:

  • USB 驱动器 (MBR):Grub 2
  • USB 驱动器(hd0、msdos1):ext4 512Mb /boot
  • 笔记本内部磁盘:hosts.linux-loops/system0.lvm我安装操作系统并将其映射为的文件/dev/mapper/vg_system-lv_root

这是我的 Grub 2 菜单项:

set BOOT_PART=(hd0,msdos1)
set HOST_PART=(hd1,gpt5)
set LOOP_FILE=.linux-loops/system0.lvm
set LOOP_DEV=loop0
set LVM_VG=vg_system
set LVM_LV=lv_root
set ROOT_DEV=/dev/mapper/${LVM_VG}-${LVM_LV}

menuentry 'Loopback / 4.10.0-38-generic' --class ubuntu --class gnu-linux --class gnu --class os {
    echo "Initializing environment..."

    set KERN_VER=4.10.0-38-generic

    recordfail  load_video  gfxmode $linux_gfx_mode

    echo "Loading partition drivers..."

    insmod ext2
    insmod gzio
    insmod part_msdos
    insmod part_gpt

    echo Loopback(s) setup...

    loopback ${LOOP_DEV} ${HOST_PART}/${LOOP_FILE}
    insmod lvm

    echo Debug LVM...
    ls
    ls (lvm/${LVM_VG}/${LVM_LV)/

    echo "Loading kernel..."

    set root=${BOOT_PART}

    linux   /vmlinuz-${KERN_VER} root=${ROOT_DEV} rw verbose nosplash debug
    initrd /initrd.img-${KERN_VER}

}

他们俩LS调试命令显示 grub 已看到 LVM 分区,但在初始化程序运行时,系统显示该组卷组系统没有找到并且LV元数据尚未运行。

我认为 grub 脚本内的环回设置无法传播到 init 脚本,因此它无法再次初始化 LVM 映射器。

在非 LVM 场景(如上所述)中vmlinuz ...循环=...解决了问题。

问题是:如何设置环回文件以便 grub 可以将它们提供给 LVM 映射器?

太感谢了!

答案1

您的想法是正确的:GRUB 无法代表内核进行设置。

GRUB 依赖系统固件(BIOS 或 UEFI)进行磁盘访问,因此它所做的任何事情都基于这些固件例程。一旦内核接管,这些固件例程就不再使用......并且在它们之上构建的任何东西也变得不可用,直到操作系统为相同的工作提供自己的驱动程序。

(就 BIOS 而言,当内核将处理器转换为完整的 32/64 位模式时,16 位 BIOS 磁盘访问例程将变得不可用。就 UEFI 而言,我认为磁盘访问服务是 UEFI 功能之一当执行标准“终止启动服务”UEFI 调用时变得不可用,从而完成 UEFI 端将硬件控制权移交给操作系统的过程。)

相反,您需要在很早的阶段设置一个要在 initrd 中执行的脚本:它应该在 LVM 启动之前激活必要的环回设备,或者如果 LVM 是,则在设置环回设备之后执行vgscan --mknodesand/orvgchange -ay <name of the VG containing the root filesystem>已经初始化了。

如果不知道您正在使用的 Linux 发行版的名称和版本,就很难给出更具体的建议。

答案2

我已经在 GitHub 上发布了我的解决方案:

本指南将详细说明如何在 LVM 环回磁盘上安装 Linux,并从 USB 驱动器(grub 和引导分区)引导,而无需更改 PC 内部磁盘引导扇区。

相关部分已由https://github.com/antonio-petricca/buddy-linux/blob/master/assets/initramfs/lvm-loops-setup脚本:

#!/bin/sh -e

# Antonio Petricca <[email protected]> - 17/03/2018

PREREQS=""

# Output pre-requisites

prereqs() {
    echo "$PREREQ" }

case "$1" in
    prereqs)
        prereqs
        exit 0
    ;; esac

. /scripts/functions

MNT=/host ROOT_MNT=${rootmnt}${MNT}

_log_msg "Moving LVM loops host device mount point from \"${MNT}\" to {ROOT_MNT}\"...\n"

mount -o remount,rw ${rootmnt} || panic "Cannot remount \"${rootmnt}\" R/W."

[ -d ${ROOT_MNT} ] || mkdir -p ${ROOT_MNT} || panic "Cannot create \"${ROOT_MNT}\" mount point."

mount -n -o move ${MNT} ${ROOT_MNT} || panic "Cannot move \"${MNT}\" to \"${ROOT_MNT}\"."

log_end_msg "Done"

相关内容