AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 1129269
Accepted
MrCalvin
MrCalvin
Asked: 2019-03-28 15:14:34 +0800 CST2019-03-28 15:14:34 +0800 CST 2019-03-28 15:14:34 +0800 CST

使用自定义引导加载程序 ID 安装 grub,例如“MyUbuntu”

  • 772

我可以使用默认引导加载程序 ID“ ubuntu ”重新安装 grub

但是如果我使用像“ MyUbuntu ”这样的自定义名称,我将无法成功安装 grub。

在启动良好的 Ubuntu 18.04 上测试安装:

1:删除现有的grub:

rm -r /boot/efi/EFI/*

2:安装新的grub:

grub-install --target=x86_64-efi --bootloader-id=MyUbuntu /dev/sda

2:更新grub:

update-grub

系统现在启动到 Grub 控制台。EFI 在引导菜单中看到新的引导条目就好了。

在此处输入图像描述 在此处输入图像描述

刚刚进入高峰/boot/grub/grub.cfg,它仍然说: menuentry 'Ubuntu' --class ubuntu.....

grub2
  • 3 3 个回答
  • 4905 Views

3 个回答

  • Voted
  1. Best Answer
    MrCalvin
    2019-04-22T02:24:38+08:002019-04-22T02:24:38+08:00

    在我作为引导加载程序遇到systemd-boot之后,我再也没有回头看 GRUB。 systemd-boot,在我看来,更稳定并且有更好的配置方式。我所说的“稳定”是指它不像 GRUB 那样脆弱。GRUB 很容易被破解。只需在您的盒子中添加一个新磁盘就会给您带来很大的麻烦(因为您可能无法更改相同的引导加载程序 ID 等)

    systemd-boot的唯一缺点是缺乏安全启动支持,但这对我来说不是问题,而且您的内核必须位于 EFI 分区,而不是根分区,就像 GRUP 一样。

    使用systemd-boot我重新获得了对引导过程的完全控制权......是的

    它应该是默认的引导加载程序而不是 GRUB。

    更新,如何做(Debian/Ubuntu):(
    这是一个相当肤浅的指南,但我希望它能让你开始。其他来源:Ahrlinux..、freedesktop..和自述文件..)

    1:首先将内核文件从你的根分区复制,例如/boot/vmlinuz-4.9.0-8-amd64和/boot/initrd.img-4.9.0-8-amd64,到你的EFI分区。您可以将它们放在您选择的子文件夹中,如果您愿意,甚至可以放在根文件夹中。

    2:许多指南说您需要访问 EFI 变量,但我不确定这是否需要。但是要测试是否有,请运行efivar --list.
    缺少时安装:apt install efivar

    3:将systemd-boot loader 安装到 EFI 分区:(bootctl --path=/mnt/efi install使用您自己的安装 EFI 分区的路径)

    4:将文件编辑为/mnt/efi/loader/loader.conf:

    timeout 5
    # default 6a9857a393724b7a981ebb5b8495b9e-*
    

    (还没有弄清楚如何使用文件中自动添加的UUID,所以我只是将其标记出来)

    5:每个文件/mnt/efi/loader/entries/*.conf对应systemd-boot菜单中的boot-entry。因此,要添加您当前的操作系统,请创建一个类似于以下内容的文件:

    title      Debian 9 :-)
    linux      /debian9/vmlinuz-4.9.0-6-amd64
    initrd     /debian9/initrd.img-4.9.0-6-amd64
    options    root=UUID=084917b7-8be2-4e86-838d-f771a9902e08`
    

    (修改您在步骤 1 中复制的内核文件的路径。将 UUID 修改为根分区的文件系统-UUID(使用 Linux 命令lsblk -o name,uuid)

    一般信息:
    bootctl将在您的 EFI 分区中安装两个引导加载程序文件:

    ../BOOT/BOOTX64.EFI
    ../systemd/systemd-bootx64.efi
    

    这些文件是相同的。主板上的 EFI BIOS 必须引导/指向其中之一。要么直接在 BIOS 中执行,要么使用 Linux 命令efibootmgr....

    要添加新的引导条目,只需创建一个/mnt/efi/loader/entries/*.conf指向正确内核文件和根分区的新文件。

    内核文件必须位于 EFI 分区 (FAT32)。
    EFI 分区的大小必须相应调整。我认为例如 Debian/Ubuntu 的内核文件大约是 50-60MB。因此,如果您有两个安装,则需要 120MB。

    • 2
  2. dgow
    2020-03-17T12:15:31+08:002020-03-17T12:15:31+08:00

    我使用一个简单的解决方法。运行grub-install后--bootloader-id,grub-install不带任何参数运行。它将创建一个 ubuntu 条目。如果你想删除它,但现在你的 id 将“神奇地”工作。很烦人,好像是老bug了。希望我能帮上忙。

    • 0
  3. mpb
    2022-05-05T07:54:31+08:002022-05-05T07:54:31+08:00

    正如gdeff 所提到的,要自定义安装 Grub --bootloader-id,也可以使用该选项--no-uefi-secure-boot。例如:

    grub-install                \
      --target=x86_64-efi       \
      --no-uefi-secure-boot     \
      --bootloader-id=MyUbuntu  \
      /dev/sda
    

    此外,请确保在您的系统上禁用 SecureBoot。

    解释

    grub-install如果您想更好地理解、grubx64.efi、grub.cfg和 SecureBoot之间的交互,您只需阅读下面的说明(不幸的是,很长) 。

    • SecureBoot 将仅启动.efi由 Microsoft 加密签名的文件。
    • 在 Ubuntu 系统上,该文件/boot/efi/EFI/ubuntu/grubx64.efi通常来自以下两个位置之一:
    • 选项 1: grubx64.efi是由 Canonical 提供的静态、不变、Microsoft 签名、与 SecureBoot 兼容的“二进制 blob”Grub 引导加载程序。这是默认选项。
    • 选项 2: grubx64.efi在您运行时在您的系统上创建grub-install。在这种情况下,grubx64.efi未签名,因此与 SecureBoot 不兼容。

    使用选项 1(规范提供,与 SecureBoot 兼容grubx64.efi):

    • 通常会有两个grub.cfg文件。
    • 第一阶段grub.cfg在/boot/efi/EFI/ubuntu/grub.cfg
    • 第二阶段grub.cfg在/boot/grub/grub.cfg
    • 阶段 1grub.cfg文件包含grubx64.efi查找和读取阶段 2grub.cfg文件所需的信息。
    • grub.cfg第 1 阶段文件的路径/boot/efi/EFI/ubuntu/grub.cfg无法更改。改变这条道路需要改变grubx64.efi自己。更改grubx64.efi将使签名无效,使其与 SecureBoot 不兼容。

    使用选项 2(定制grubx64.efi):

    • 没有阶段 1grub.cfg文件,因为...
    • 定制grubx64.efi引导加载程序为了查找和读取阶段 2grub.cfg文件 ( /boot/grub/grub.cfg) 所需的所有配置信息都直接嵌入到定制grubx64.efi文件本身中。
    • 这是可能的,因为定制的grubx64.efi引导加载程序与 SecureBoot 不兼容,因此不需要由 Microsoft 签名。

    如果您在grub-install 有 --bootloader_id=和没有 --no-uefi-secure-boot的情况下运行,则:

    • grub-install将使用 Microsoft 签名的、由规范提供的grubx64.efi文件。(这是上面的选项 1。)
    • 此grubx64.efi文件和定制的阶段 1grub.cfg文件将安装在:/boot/efi/EFI/$bootloader_id/
    • 但是,在启动时,grubx64.efi文件将尝试读取/boot/efi/EFI/ubuntu/grub.cfg(因为无法更改此路径)。
    • 如果/boot/efi/EFI/ubuntu/grub.cfg不存在,则引导将失败。
    • 如果/boot/efi/EFI/ubuntu/grub.cfg确实存在,但来自同一系统上不同的 Ubuntu 安装,则引导可能会失败,或者grubx64.efi可能引导其他 Ubuntu 系统而不是所需的 Ubuntu 系统。
    • 另外:在这种情况下(即--no-uefi-secure-boot不存在的地方),可以说:grub-install应该产生错误(或至少是响亮的警告),而不是默默地安装一个很可能配置不正确的引导加载程序。

    或者,如果您使用 运行grub-install , --no-uefi-secure-boot则:

    • grub-install将创建一个定制的(和未签名的)grubx64.efi文件。
    • 中不会有阶段 1grub.cfg文件/boot/efi/EFI/$bootloader_id/。
    • 该grubx64.efi文件本身将能够grub.cfg在/boot/grub/grub.cfg.

    如本答案顶部所述,如果您使用--no-uefi-secure-boot,则(当然)需要确保系统上的 SecureBoot 已关闭。

    • 0

相关问题

  • 有没有办法从 GUI/桌面管理我的 Grub 菜单选项?

  • grub 菜单中的“恢复”选项是什么?

  • 与 Grub 相比,使用 Grub2 有什么好处?

  • 如果旧版 grub 安装在引导分区扇区而不是 MBR 中,如何将 grub 更新为 grub2?

  • 如何在 Ubuntu 启动时显示或隐藏启动消息?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve