为什么 GRUB 2 会给我一个恢复命令行,除非我从该命令行重新启动?

为什么 GRUB 2 会给我一个恢复命令行,除非我从该命令行重新启动?

当我启动计算机时,无论是通过操作系统软件重启按钮还是笔记本电脑上的物理电源按钮,GRUB 都会给我一个命令行。

这本身并不奇怪。我只是假设我配置错误了,但如果我reboot在 GRUB 的命令行中输入,我的电脑就会重新启动,并且GRUB 给我正常的启动菜单,好像什么都没发生一样。

如果我按下c正常启动菜单再次获取命令行,然后输入reboot该命令行,GRUB 仍会在重启后返回正常菜单。

什么原因导致 GRUB 2 仅在其自己的命令行启动重新启动时才能成功初始化?

我正在双启动 Windows 7 和 Arch Linux,都是 64 位的。我使用的是 MBR,而不是 UEFI。以下是 的内容,它是由 Arch 的工具/boot/grub/grub.cfg自动生成的。grub-mkconfig

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

### BEGIN /etc/grub.d/00_header ###
insmod part_gpt
insmod part_msdos
if [ -s $prefix/grubenv ]; then
  load_env
fi
if [ "${next_entry}" ] ; then
   set default="${next_entry}"
   set next_entry=
   save_env next_entry
   set boot_once=true
else
   set default="2"
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}"
    save_env saved_entry
  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
}

set menu_color_normal=white/red
set menu_color_highlight=red/white

if [ x$feature_default_font_path = xy ] ; then
   font=unicode
else
insmod part_msdos
insmod ext2
set root='hd0,msdos5'
if [ x$feature_platform_search_hint = xy ]; then
  search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos5 --hint-efi=hd0,msdos5 --hint-baremetal=ahci0,msdos5  cdd2682e-3d7c-476f-bca9-9ce2d5be28f7
else
  search --no-floppy --fs-uuid --set=root cdd2682e-3d7c-476f-bca9-9ce2d5be28f7
fi
    font="/usr/share/grub/unicode.pf2"
fi

if loadfont $font ; then
  set gfxmode=auto
  load_video
  insmod gfxterm
  set locale_dir=$prefix/locale
  set lang=en_US
  insmod gettext
fi
terminal_input console
terminal_output gfxterm
set timeout=30
### END /etc/grub.d/00_header ###

### BEGIN /etc/grub.d/10_linux ###
menuentry 'Arch Linux, with Linux core repo kernel' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-core repo kernel-true-cdd2682e-3d7c-476f-bca9-9ce2d5be28f7' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='hd0,msdos5'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos5 --hint-efi=hd0,msdos5 --hint-baremetal=ahci0,msdos5  cdd2682e-3d7c-476f-bca9-9ce2d5be28f7
    else
      search --no-floppy --fs-uuid --set=root cdd2682e-3d7c-476f-bca9-9ce2d5be28f7
    fi
    echo    'Loading Linux core repo kernel ...'
    linux   /boot/vmlinuz-linux root=UUID=cdd2682e-3d7c-476f-bca9-9ce2d5be28f7 ro  quiet
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initramfs-linux.img
}
menuentry 'Arch Linux, with Linux core repo kernel (Fallback initramfs)' --class arch --class gnu-linux --class gnu --class os $menuentry_id_option 'gnulinux-core repo kernel-fallback-cdd2682e-3d7c-476f-bca9-9ce2d5be28f7' {
    load_video
    set gfxpayload=keep
    insmod gzio
    insmod part_msdos
    insmod ext2
    set root='hd0,msdos5'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos5 --hint-efi=hd0,msdos5 --hint-baremetal=ahci0,msdos5  cdd2682e-3d7c-476f-bca9-9ce2d5be28f7
    else
      search --no-floppy --fs-uuid --set=root cdd2682e-3d7c-476f-bca9-9ce2d5be28f7
    fi
    echo    'Loading Linux core repo kernel ...'
    linux   /boot/vmlinuz-linux root=UUID=cdd2682e-3d7c-476f-bca9-9ce2d5be28f7 ro  quiet
    echo    'Loading initial ramdisk ...'
    initrd  /boot/initramfs-linux-fallback.img
}

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

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

### BEGIN /etc/grub.d/30_os-prober ###
menuentry 'Windows 7 (loader) (on /dev/sda2)' --class windows --class os $menuentry_id_option 'osprober-chain-CE7C7A0D7C79F097' {
    insmod part_msdos
    insmod ntfs
    set root='hd0,msdos2'
    if [ x$feature_platform_search_hint = xy ]; then
      search --no-floppy --fs-uuid --set=root --hint-bios=hd0,msdos2 --hint-efi=hd0,msdos2 --hint-baremetal=ahci0,msdos2  CE7C7A0D7C79F097
    else
      search --no-floppy --fs-uuid --set=root CE7C7A0D7C79F097
    fi
    chainloader +1
}
### END /etc/grub.d/30_os-prober ###

### 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/60_memtest86+ ###
### END /etc/grub.d/60_memtest86+ ###

答案1

我记得在不同场合出现过类似的问题,并且我开始注意到每当内核升级或 grub 升级时就会发生这种情况(无论如何我相信如此,重新安装总能解决问题)。

至少让 Arch 重新生成 grub.cfg,尽管这听起来有点像 initrd/initramfs 和 grub 不同步。还有一个启动资源可能值得检查,但我记不清了。

无论如何,如果您进行了任何更新/安装,请检查您的系统日志并找出它们是什么,然后一次撤消一个,或者将它们全部回滚。

也许您的 BIOS 也会出现问题,但更有可能的是软件包更新未能正常同步。

相关内容