记一次解决Fedora25上grub2-reboot命令不生效的经历

2023-11-02 20:32

本文主要是介绍记一次解决Fedora25上grub2-reboot命令不生效的经历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Gurb2命令不生效

这段时间我一直被一个问题困扰,那就是我使用grub2-reboot命令,明明是执行成功了:

[cshih@SCHEN-TOSHIBAPC ~]$ sudo grub2-reboot 2
[cshih@SCHEN-TOSHIBAPC ~]$ sudo grub2-editenv list
saved_entry=Fedora (4.8.6-300.fc25.x86_64) 25 (Workstation Edition)
next_entry=2
[cshih@SCHEN-TOSHIBAPC ~]$ 

但重启之后就是不按照我的设定引导(应该引导第三条记录)。

从官方文档上看,grub2-rebootgrub2-set-default都是用来指定引导目标的,但与后者最大的区别在于,前者并不改变默认选项,仅仅是在下次启动时换个引导目标,这正是我需要的功能。

备注:grub2-set-default应该也不会生效,虽然没有试过,但我觉得是这样的。

研究过程

,我也尝试了百度和谷歌各种关键字,但可能碰到这个问题的人不多,更不会有人费力气总结出来,所以我一个明确的案例都没看到。

后来,我在一台比较新的机器上,重新尝试了这些操作,没有遇到任何问题。很显然,安装的系统和我的操作是一模一样的,但结果却是不同的,那么问题很可能就出在硬件差异上。加上之前的搜索,让我有了Legacy BIOSUEFI需要区别对待的概念。最终,我才想明白了整个问题。

解决办法

[cheshi@dhcp-14-110 grub2]$ ls -la grubenv 
lrwxrwxrwx. 1 root root 28 Dec  8  2016 grubenv -> /boot/efi/EFI/fedora/grubenv
[cheshi@dhcp-14-110 grub2]$ sudo rm grubenv 
[cheshi@dhcp-14-110 grub2]$ sudo ln -s ../efi/EFI/fedora/grubenv grubenv
[cheshi@dhcp-14-110 grub2]$ ls -la grubenv 
lrwxrwxrwx. 1 root root 25 Jul 21 13:41 grubenv -> ../efi/EFI/fedora/grubenv

说到解决办法,其根本就在于,你要想到grub2支持两种引导方式,即Legacy BIOSUEFI,而我感觉,现在的grub2默认支持的是UEFI而不是传统的Legacy BIOS,所以如果你的机器像我的一样,已有一些年头,你尤其要注意这个问题。

解决这个问题,我用了下面的语句:

[root@SCHEN-TOSHIBAPC ~]# mv /boot/grub2/grubenv /boot/grub2/grubenv.bak 
[root@SCHEN-TOSHIBAPC ~]# cp /boot/grub2/grubenv.bak /boot/grub2/grubenv
[root@SCHEN-TOSHIBAPC ~]# ls -la /boot/grub2/grubenv*
-rw-r--r--. 1 root root 1024 Jul  9 11:01 /boot/grub2/grubenv
lrwxrwxrwx. 1 root root   28 Jun 11  2016 /boot/grub2/grubenv.bak -> /boot/efi/EFI/fedora/grubenv
[root@SCHEN-TOSHIBAPC ~]# 

这样,grub2-reboot命令和整个引导过程就可以正常运作了。

http://fedoraproject.org/wiki/GRUB_2

Note
The above method fails to work on some F20 (and newer) systems due to a missing or improperly linked /boot/grub2/grubenv file. The /boot/grub2/grubenv is symbolic linked to /boot/efi/EFI/fedora/grubenv but /boot is not mounted at the time of booting. So grub2 does not have access to the environment variables. To fix this, change /boot/grub2/grubenv to point to ../efi/EFI/fedora/grubenv instead and your chosen default OS will boot without any problems.

原因分析

我这台老机器的主板怎么也有10年了,所以肯定属于Legacy BIOS的情况。而grub2刚出没几年,所以要说存在兼容性问题,那也是有可能的。

其实/boot/grub2/grubenv是一个指向/boot/efi/EFI/fedora/grubenv的符号链接(软链接)。这使我想到,如果我的系统只支持Legacy BIOS而不支持UEFI那么即便/boot/efi/EFI/fedora/下面的文件配置得再正确,也可能根本用不到。

而当我打开文件一看,更加印证了我的猜测,因为我刚刚运行grub2-reboot 2的结果,就以next_entry=2的形式保存在这个文件中。

那么既然我在引导过程中,读不到被链接的这个文件,那么我就把“符号链接”变成一个真实的文件,这样肯定就能读到了,于是问题也就解决了。

问题回顾

这个问题,我觉得还是因为grub2本身对Legacy BIOS的支持不够完善。不过话说回来,我也不认为它会去完善这个支持,必定用Legacy BIOS的人已经寥寥无几,并且还会越来越少。

这部分人就自求多福吧,但愿自己的技术还可以,足够驾驭这些挑战,不然的话,还是赶紧更新换代自己的设备吧。哈哈!!

reference

https://fedoraproject.org/wiki/GRUB_2
http://blog.csdn.net/silicon_inspecter/article/details/54809958

这篇关于记一次解决Fedora25上grub2-reboot命令不生效的经历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/333128

相关文章

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻