记一次解决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

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁