Linux系统中的GRUB(Grand Unified Bootloader)是引导加载程序的核心组件,负责在开机时初始化硬件、加载操作系统内核并启动系统,用户可能需要更改GRUB配置以满足个性化需求,例如设置默认启动项、调整启动等待时间、添加自定义内核参数或修复启动问题,但GRUB配置直接关系到系统启动,操作前必须备份原配置文件,避免因配置错误导致无法启动,以下将详细介绍Linux系统中更改GRUB的完整步骤及注意事项。

更改GRUB前的准备工作:备份配置文件
GRUB的核心配置文件通常位于/etc/default/grub(Debian/Ubuntu系)或/boot/grub2/grub.cfg(CentOS/RHEL系),其中存储了启动菜单、默认项、超时时间等关键参数,修改前需先备份,防止配置错误导致系统无法启动。
- Debian/Ubuntu系:
sudo cp /etc/default/grub /etc/default/grub.bak
- CentOS/RHEL系:
sudo cp /boot/grub2/grub.cfg /boot/grub2/grub.cfg.bak
修改GRUB核心配置参数
GRUB的行为由/etc/default/grub文件中的参数控制,可通过文本编辑器(如nano、vim)打开并修改,以下是常用参数的修改方法:
设置默认启动项
GRUB_DEFAULT参数用于指定默认启动的操作系统,其值可以是菜单项的索引(从0开始)或菜单项标题(如”Ubuntu”)。
- 示例:若启动菜单有两个选项(Ubuntu、Windows),将
GRUB_DEFAULT设为0则默认启动Ubuntu,设为1则默认启动Windows;若设为"Advanced options for Ubuntu",则会匹配标题完全一致的菜单项。 - 修改命令(以
nano为例):sudo nano /etc/default/grub
找到
GRUB_DEFAULT=0行,根据需求修改后保存(Ctrl+O→回车→Ctrl+X)。
调整启动等待时间
GRUB_TIMEOUT参数控制启动菜单的显示等待时间(单位:秒),默认为10秒,若设为-1则始终显示菜单,设为0则直接进入默认启动项。

- 示例:将等待时间缩短至5秒,修改为
GRUB_TIMEOUT=5。
隐藏启动菜单
若希望不显示启动菜单(直接进入默认系统),可设置GRUB_HIDDEN_TIMEOUT=0,但此参数可能影响紧急情况下的启动项选择(如进入恢复模式),建议谨慎使用。
添加内核启动参数
GRUB_CMDLINE_LINUX参数用于为Linux内核添加启动选项,例如quiet splash(简化启动信息)、nomodeset(解决显卡黑屏问题)、rootfstype=ext4(指定文件系统类型)等。
- 示例:添加
nomodeset解决NVIDIA显卡黑屏问题,修改为:GRUB_CMDLINE_LINUX="nomodeset"
添加自定义启动项
若需添加非检测到的系统(如Windows、其他Linux发行版),或创建带特定参数的启动项,可通过编辑自定义配置文件实现。
创建自定义启动项文件
在/etc/grub.d/目录下创建自定义文件(如/etc/grub.d/40_custom),文件名以数字开头(数字越小,优先级越高),内容参考以下格式:
menuentry "Custom OS" {
insmod ntfs # 加载NTFS文件系统模块(若为Windows分区)
set root='hd0,msdos1' # 指定系统分区,hd0表示第一块硬盘,msdos1表示第一个分区
chainloader +1 # 加载引导扇区
}
- 说明:
set root需根据实际分区调整,可通过sudo fdisk -l查看分区表;若为Linux系统,可替换为linux和initrd指令指定内核和initrd文件。
更新GRUB配置文件
修改或添加配置后,需运行更新命令生成新的grub.cfg文件,否则配置不生效。

- Debian/Ubuntu系:
sudo update-grub
- CentOS/RHEL系:
sudo grub2-mkconfig -o /boot/grub2/grub.cfg
常用GRUB配置参数说明
以下是/etc/default/grub中常用参数及其作用,可通过表格快速查阅:
| 参数名 | 默认值 | 说明 | 示例 |
|---|---|---|---|
| GRUB_DEFAULT | 0 | 默认启动项(索引或标题) | GRUB_DEFAULT="Ubuntu" |
| GRUB_TIMEOUT | 10 | 启动菜单等待时间(秒) | GRUB_TIMEOUT=5 |
| GRUB_HIDDEN_TIMEOUT | 无 | 隐藏菜单的等待时间(0表示不隐藏) | GRUB_HIDDEN_TIMEOUT=0 |
| GRUB_CMDLINE_LINUX | 无 | Linux内核启动参数 | GRUB_CMDLINE_LINUX="quiet" |
| GRUB_DISABLE_LINUX_UUID | false | 是否禁用UUID(使用设备路径代替) | GRUB_DISABLE_LINUX_UUID=true |
| GRUB_TERMINAL | console | 终端类型(console、gfxterm等) | GRUB_TERMINAL=gfxterm |
注意事项
- 备份优先:修改前务必备份配置文件,避免配置错误导致无法启动。
- UEFI与Legacy区别:UEFI启动模式下,GRUB配置文件可能位于
/boot/efi/EFI/ubuntu/grub.cfg,需通过efi grub-install安装引导。 - 权限问题:修改
/etc/default/grub需root权限,普通用户需通过sudo执行。
相关问答FAQs
Q1:更改GRUB配置后无法启动系统,如何恢复?
A:可通过Live USB启动盘进入救援模式:
- 用Live USB启动,选择“Try Ubuntu”或“Rescue Mode”;
- 挂载原系统分区(如
sudo mount /dev/sda1 /mnt); - 进入
/mnt/etc,恢复备份的grub文件(sudo cp grub.bak grub); - 重新安装GRUB(
sudo grub-install --target=i386-pc /dev/sda,Legacy模式;UEFI模式需指定--target=x86_64-efi --efi-directory=/boot/efi); - 更新配置(
sudo update-grub),重启即可。
Q2:如何为GRUB设置启动密码,防止他人修改启动项?
A:可通过以下步骤设置GRUB启动密码:
- 生成密码哈希(
echo -e "your_passwordnyour_password" | grub-mkpasswd-pbkdf2,记录输出的哈希值,如GRUB_PBKDF2_HASH=grub.pbkdf2.sha512.10000...); - 编辑
/etc/grub.d/00_header文件,在if [ -n "${GRUB2_PASSWORD}" ]; then部分添加:cat << EOF set superusers="root" password_pbkdf2 root ${GRUB_PBKDF2_HASH} EOF - 更新GRUB配置(
sudo update-grub),重启后启动菜单需输入密码才能修改启动项。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/29404.html