我的 Grub2 非常完美,除了手动(编辑 grub.cfg)之外我无法更新它。我该如何清理这个?

我的 Grub2 非常完美,除了手动(编辑 grub.cfg)之外我无法更新它。我该如何清理这个?

我在 Acer 笔记本电脑上运行 openSUSE Tumbleweed。请随时在评论中询问任何可能重要的硬件/软件详细信息。

我的问题是:

> sudo grub2-mkconfig -o /boot/grub2/grub.cfg    
insmod: ERROR: could not load module part_msdos: No such file or directory

不过我想我知道问题出在哪里: my/etc/default/grub与 my 相同(非常长且复杂)/boot/grub2/grub.cfg。 (当我删除part_msdosin的每个实例时/etc/default/grub,我收到另一个错误,然后又一个错误......这是无止境的)。

为了解决这个问题,我保存了旧grub文件并将其替换为一个干净的“新”文件,其中仅包含GRUB_DEFAULT=和 之类的条目GRUB_TIMEOUT=

然后我可以生成一个新的grub.cfg,但当然在启动时一切都立即失败,我最终进入了grub-repair >.

所以这是我真正的问题:我希望该grub2-mkconfig命令能够实际工作,以便我可以用它更新我的 Grub,但是......我当前的 Grub 在启动时看起来、感觉和行为都很完美,所以我想保留它。

我不知道这是否可能,但如果有人知道该怎么做......

谢谢!


编辑: 这就是我听你说的。

  1. 我备份/etc/default/grub然后删除它,并用grub同一位置的一个文件替换它,其中包含以下内容:
#/etc/default/grub
GRUB_DEFAULT="0"
GRUB_TIMEOUT="5"
GRUB_CMDLINE_LINUX="resume=UUID=2b54516c-b818-4bfb-8305-28b0a17182d9 quiet splash"
GRUB_TERMINAL_OUTPUT="console"
GRUB_DISABLE_RECOVERY="false"
GRUB_BACKGROUND="/boot/grub2/jinx-resized.png"
GRUB_THEME="/boot/grub2/themes/openSUSE/theme.txt"
GRUB_SAVEDEFAULT="true"
GRUB_DISABLE_OS_PROBER="false"
  1. 然后我就跑了grub2-mkconfig -o /boot/grub2/grub.cfg
  2. 结果?黑色幼虫,只有两个条目:openSUSE TumbleweedRecovery for openSUSE Tumbleweed(包含 4 个条目)。当我尝试启动时,所有 5 个条目都崩溃了

所以?中的所有内容etc/grub.d都是可执行的,包括30_os-prober.

在这里我让你看看我所做的结果:

#/boot/grub2/grub.cfg
#
# DO NOT EDIT THIS FILE
#
# It is automatically generated by grub2-mkconfig using templates
# from /etc/grub.d and settings from /etc/default/grub
#

### BEGIN /etc/grub.d/00_header ###
set btrfs_relative_path="n"
export btrfs_relative_path
if [ -f ${config_directory}/grubenv ]; then
  load_env -f ${config_directory}/grubenv
elif [ -s $prefix/grubenv ]; then
  load_env
fi

if [ "${env_block}" ] ; then
  set env_block="(${root})${env_block}"
  export env_block
  load_env -f "${env_block}"
fi

if [ "${next_entry}" ] ; then
   set default="${next_entry}"
   set next_entry=
   save_env next_entry
   if [ "${env_block}" ] ; then
     save_env -f "${env_block}" next_entry
   fi
   set boot_once=true
else
   set default="0"
fi

if [ x"${feature_menuentry_id}" = xy ]; then
  menuentry_id_option="--id"
else
  menuentry_id_option=""
fi

export menuentry_id_option

if [ "${prev_saved_entry}" ]; then
  set saved_entry="${prev_saved_entry}"
  save_env saved_entry
  set prev_saved_entry=
  save_env prev_saved_entry
  set boot_once=true
fi

function savedefault {
  if [ -z "${boot_once}" ]; then
    saved_entry="${chosen}"
    if [ "${env_block}" ] ; then
      save_env -f "${env_block}" saved_entry
    else
      save_env saved_entry
    fi

  fi
}

function load_video {
  if [ x$feature_all_video_module = xy ]; then
    insmod all_video
  else
    insmod efi_gop
    insmod efi_uga
    insmod ieee1275_fb
    insmod vbe
    insmod vga
    insmod video_bochs
    insmod video_cirrus
  fi
}


for i in console; do
  if [ x${use_append} = xtrue ]; then
     terminal_output --append $i
  elif terminal_output $i; then
     use_append=true;
  fi
done

if [ x${boot_once} = xtrue ]; then
  set timeout=0
elif [ x$feature_timeout_style = xy ] ; then
  set timeout_style=menu
  set timeout=5
# Fallback normal timeout code in case the timeout_style feature is
# unavailable.
else
  set timeout=5
fi
### END /etc/grub.d/00_header ###

### BEGIN /etc/grub.d/00_tuned ###
set tuned_params=""
set tuned_initrd=""
### END /etc/grub.d/00_tuned ###

### BEGIN /etc/grub.d/05_crypttab ###
### END /etc/grub.d/05_crypttab ###

### BEGIN /etc/grub.d/05_menu_color ###
set menu_color_normal=white/black
set menu_color_highlight=black/light-gray
### END /etc/grub.d/05_menu_color ###

### BEGIN /etc/grub.d/10_linux ###
menuentry 'openSUSE Tumbleweed'  --class opensuse --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-simple-37b1ace3-0889-4b40-9b0a-a2fe5da56d0a' {
    savedefault
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos
    insmod btrfs
    set root='hd0,msdos1'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
    else
      search --no-floppy --fs-uuid --set=root 37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
    fi
    echo    'Loading Linux 6.5.8-1-default ...'
    linux   /@/.snapshots/709/snapshot/boot/vmlinuz-6.5.8-1-default root=UUID=37b1ace3-0889-4b40-9b0a-a2fe5da56d0a rootflags=subvol=@/.snapshots/709/snapshot resume=UUID=2b54516c-b818-4bfb-8305-28b0a17182d9 quiet splash 
    echo    'Loading initial ramdisk ...'
    initrd  /@/.snapshots/709/snapshot/boot/initrd-6.5.8-1-default
}
submenu 'Advanced options for openSUSE Tumbleweed' --hotkey=1 $menuentry_id_option 'gnulinux-advanced-37b1ace3-0889-4b40-9b0a-a2fe5da56d0a' {
    menuentry 'openSUSE Tumbleweed, with Linux 6.5.8-1-default' --hotkey=2 --class opensuse --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.8-1-default-advanced-37b1ace3-0889-4b40-9b0a-a2fe5da56d0a' {
    savedefault
        load_video
        set gfxpayload=keep
        insmod gzio
        insmod part_msdos
        insmod btrfs
        set root='hd0,msdos1'
        if [ x$feature_platform_search_hint = xy ]; then
          search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        else
          search --no-floppy --fs-uuid --set=root 37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        fi
        echo    'Loading Linux 6.5.8-1-default ...'
        linux   /@/.snapshots/709/snapshot/boot/vmlinuz-6.5.8-1-default root=UUID=37b1ace3-0889-4b40-9b0a-a2fe5da56d0a rootflags=subvol=@/.snapshots/709/snapshot resume=UUID=2b54516c-b818-4bfb-8305-28b0a17182d9 quiet splash 
        echo    'Loading initial ramdisk ...'
        initrd  /@/.snapshots/709/snapshot/boot/initrd-6.5.8-1-default
    }
    menuentry 'openSUSE Tumbleweed, with Linux 6.5.8-1-default (recovery mode)' --hotkey=3 --class opensuse --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.8-1-default-recovery-37b1ace3-0889-4b40-9b0a-a2fe5da56d0a' {
        load_video
        set gfxpayload=keep
        insmod gzio
        insmod part_msdos
        insmod btrfs
        set root='hd0,msdos1'
        if [ x$feature_platform_search_hint = xy ]; then
          search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        else
          search --no-floppy --fs-uuid --set=root 37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        fi
        echo    'Loading Linux 6.5.8-1-default ...'
        linux   /@/.snapshots/709/snapshot/boot/vmlinuz-6.5.8-1-default root=UUID=37b1ace3-0889-4b40-9b0a-a2fe5da56d0a single rootflags=subvol=@/.snapshots/709/snapshot resume=UUID=2b54516c-b818-4bfb-8305-28b0a17182d9 quiet splash
        echo    'Loading initial ramdisk ...'
        initrd  /@/.snapshots/709/snapshot/boot/initrd-6.5.8-1-default
    }
    menuentry 'openSUSE Tumbleweed, with Linux 6.5.6-1-default'  --class opensuse --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.6-1-default-advanced-37b1ace3-0889-4b40-9b0a-a2fe5da56d0a' {
    savedefault
        load_video
        set gfxpayload=keep
        insmod gzio
        insmod part_msdos
        insmod btrfs
        set root='hd0,msdos1'
        if [ x$feature_platform_search_hint = xy ]; then
          search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        else
          search --no-floppy --fs-uuid --set=root 37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        fi
        echo    'Loading Linux 6.5.6-1-default ...'
        linux   /@/.snapshots/709/snapshot/boot/vmlinuz-6.5.6-1-default root=UUID=37b1ace3-0889-4b40-9b0a-a2fe5da56d0a rootflags=subvol=@/.snapshots/709/snapshot resume=UUID=2b54516c-b818-4bfb-8305-28b0a17182d9 quiet splash 
        echo    'Loading initial ramdisk ...'
        initrd  /@/.snapshots/709/snapshot/boot/initrd-6.5.6-1-default
    }
    menuentry 'openSUSE Tumbleweed, with Linux 6.5.6-1-default (recovery mode)' --hotkey=1 --class opensuse --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-6.5.6-1-default-recovery-37b1ace3-0889-4b40-9b0a-a2fe5da56d0a' {
        load_video
        set gfxpayload=keep
        insmod gzio
        insmod part_msdos
        insmod btrfs
        set root='hd0,msdos1'
        if [ x$feature_platform_search_hint = xy ]; then
          search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos1 --hint-efi=hd0,msdos1 --hint-baremetal=ahci0,msdos1  37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        else
          search --no-floppy --fs-uuid --set=root 37b1ace3-0889-4b40-9b0a-a2fe5da56d0a
        fi
        echo    'Loading Linux 6.5.6-1-default ...'
        linux   /@/.snapshots/709/snapshot/boot/vmlinuz-6.5.6-1-default root=UUID=37b1ace3-0889-4b40-9b0a-a2fe5da56d0a single rootflags=subvol=@/.snapshots/709/snapshot resume=UUID=2b54516c-b818-4bfb-8305-28b0a17182d9 quiet splash
        echo    'Loading initial ramdisk ...'
        initrd  /@/.snapshots/709/snapshot/boot/initrd-6.5.6-1-default
    }
}

### END /etc/grub.d/10_linux ###

### BEGIN /etc/grub.d/20_linux_xen ###

### END /etc/grub.d/20_linux_xen ###

### BEGIN /etc/grub.d/20_memtest86+ ###
### END /etc/grub.d/20_memtest86+ ###

### BEGIN /etc/grub.d/25_bli ###
if [ "$grub_platform" = "efi" ]; then
  insmod bli
fi
### END /etc/grub.d/25_bli ###

### BEGIN /etc/grub.d/30_os-prober ###

### END /etc/grub.d/30_os-prober ###

### BEGIN /etc/grub.d/30_uefi-firmware ###
if [ "$grub_platform" = "efi" ]; then
    menuentry 'UEFI Firmware Settings' $menuentry_id_option 'uefi-firmware' {
                fwsetup --is-supported
                if [ "$?" = 0 ]; then
                        fwsetup
                else
                        echo "Your firmware doesn't support setup menu entry from a boot loader"
                        echo "Press any key to return ..."
                        read
                fi
        }
fi
### END /etc/grub.d/30_uefi-firmware ###

### BEGIN /etc/grub.d/35_fwupd ###
### END /etc/grub.d/35_fwupd ###

### BEGIN /etc/grub.d/40_custom ###
# This file provides an easy way to add custom menu entries.  Simply type the
# menu entries you want to add after this comment.  Be careful not to change
# the 'exec tail' line above.
### END /etc/grub.d/40_custom ###

### BEGIN /etc/grub.d/41_custom ###
if [ -f  ${config_directory}/custom.cfg ]; then
  source ${config_directory}/custom.cfg
elif [ -z "${config_directory}" -a -f  $prefix/custom.cfg ]; then
  source $prefix/custom.cfg
fi
### END /etc/grub.d/41_custom ###

### BEGIN /etc/grub.d/80_suse_btrfs_snapshot ###
### END /etc/grub.d/80_suse_btrfs_snapshot ###

### BEGIN /etc/grub.d/90_persistent ###
### END /etc/grub.d/90_persistent ###

### BEGIN /etc/grub.d/95_textmode ###
if [ "${grub_platform}" = "efi" ]; then
  # On EFI systems we can only have graphics *or* serial, so allow the user
  # to switch between the two
  hiddenentry 'Text mode' --hotkey 't' {
    set textmode=true
    terminal_output console
  }
fi
### END /etc/grub.d/95_textmode ###

我的快速分析:Grub 创建了所有指向内核和 initramfs 的 Tumbleweed 条目快照,不一定再存在了。并且 osprober 没有做任何事情。顺便说一句,40_custom尽管我确实有可执行文件,但我还没有添加任何内容。

结束词:感谢上帝,我备份了一切,并且不相信无所不在的“修复你的配置/etc/default/grub,然后重新创建你的配置,你就会没事的!”

对于任何未来的读者:我对这篇文章的愤怒语气感到非常抱歉,只是当人们让它听起来超级简单时,我感到有点被背叛,而且它不仅不起作用,而且破坏了一切。再次抱歉

答案1

您已将 GRUB 配置命令直接写入/etc/default/grub.这是不正确的:/etc/default/grub由脚本来源grub2-mkconfig作为一部分一个 shell 脚本将创建实际的grub.cfg。该 shell 脚本的其他部分位于/etc/grub.d/.

如果您写入insmod part_msdos/etc/default/grub则将grub-mkconfig尝试执行Linux命令加载一个Linux内核模块name part_msdos,它显然不存在 - 而不是在 GRUB 配置中添加一行来告诉它加载GRUB模块part_msdos

通常,/etc/default/grub应该只包含供/etc/grub.d/.

如果您希望完全编写自己的 GRUB 配置,则应该将其命名为/boot/grub/custom.cfg.由grub2-mkconfig,调用的最后一个脚本/etc/grub.d/41_custom在它生成的任何“标准”的末尾添加了几行grub.cfg,以使 GRUB 成为源custom.cfg(如果存在)。这可以用来用您的自定义配置完全覆盖“标准样式”GRUB 配置。

或者,如果您想保留grub2-mkconfig功能的某些部分但替换其他部分,您应该查看 中的脚本/etc/grub.d/:每个脚本将负责“标准”grub.cfg文件的特定部分。您可以修改甚至完全替换其中一些脚本。

请注意,您不能直接将 GRUB 配置语言直接写入大多数这些脚本中:您必须编写一个 shell 脚本,它将输出您想要的 GRUB 配置到标准输出。

特别是,如果您只想在 生成的标准菜单之后添加自定义命令(例如其他操作系统的菜单条目)grub2-mkconfig,则应该将 GRUB 命令写入到末尾/etc/grub.d/40_custom- 这正是该脚本的用途。它有一个巧妙的两行标头,使脚本的其余部分按原样发送到标准输出,从而允许您直接编写 GRUB 配置语法。

相关内容