news 2026/6/6 2:14:28

GRUB原理与加固教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GRUB原理与加固教程

GRUB(Grand Unified Bootloader) 是 Linux 系统最常用的引导加载程序。它不仅负责加载内核,还提供了多系统切换、引导参数修改等功能。

一、 GRUB 的工作原理

由于 BIOS/UEFI 无法直接识别复杂的 Linux 文件系统(如 Ext4, LVM, XFS),GRUB 采用了分阶段引导的设计:

  1. Stage 1 (MBR/EFI Part):驻留在硬盘主引导记录或 EFI 分区中。它的唯一任务是找到并加载 Stage 1.5 或 Stage 2。
  2. Stage 1.5:包含文件系统驱动程序,使 GRUB 能够读取/boot/grub目录下的内容。
  3. Stage 2:加载图形菜单、读取配置文件(grub.cfg),并根据指令将 Linux 内核(vmlinuz)和初始化内存盘(initrd)加载到内存中。

二、 为什么要给 GRUB 加密码?

默认情况下,任何人只要能物理接触到服务器,就可以在开机时通过按e键进入编辑模式,在内核行末尾添加init=/bin/bashrd.break。这允许攻击者绕过root密码验证,直接获得最高权限的 Shell。


三、 GRUB 安全加固步骤(实战)

我们将实现:允许系统正常启动,但禁止未经授权编辑启动参数。

步骤 1:生成密码哈希值

不要使用明文密码。使用 GRUB 内置工具生成 PBKDF2 加密哈希:

grub-mkpasswd-pbkdf2

输入并确认你的密码,系统会输出一段以grub.pbkdf2.sha512...开头的长字符串。请完整复制这段字符串。

步骤 2:定义管理员用户

编辑自定义配置文件,不要直接修改grub.cfg,因为它是动态生成的。

nano/etc/grub.d/40_custom

在文件末尾添加以下内容:

setsuperusers="admin_user"password_pbkdf2 admin_user[刚才复制的哈希值]
步骤 3:解除正常启动的限制(可选但推荐)

默认情况下,设置superusers后,每次开机都要输密码。如果希望仅在编辑(按 e)时输密码,需要修改 10_linux 脚本:

# 在 --class gnu-linux 后添加 --unrestrictedsed-i's/--class gnu-linux/--class gnu-linux --unrestricted/g'/etc/grub.d/10_linux
步骤 4:更新配置生效

执行命令将修改后的逻辑同步到真正的引导文件:

update-grub

四、 验证与总结

场景行为结果
开机自动等待直接回车或等待超时正常进入系统
e编辑尝试修改内核参数提示输入用户名和密码
c命令行尝试进入 GRUB 控制台提示输入用户名和密码

五、 核心命令速查表

  • 生成密码:grub-mkpasswd-pbkdf2
  • 配置文件路径:/etc/grub.d/(脚本) 和/boot/grub/grub.cfg(最终配置)
  • 应用更改:update-grub(Debian/Ubuntu) 或grub2-mkconfig -o /boot/grub2/grub.cfg(CentOS/RHEL)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 21:22:29

无需配置!CV-UNet抠图工具一键启动指南

无需配置!CV-UNet抠图工具一键启动指南 你是否还在为一张证件照反复调整魔棒选区而头疼?是否每次处理电商主图都要花10分钟手动抠图?是否想把AI抠图能力直接用在工作流里,却卡在环境配置、模型下载、CUDA版本不兼容这些“拦路虎”…

作者头像 李华
网站建设 2026/6/1 3:21:29

Qwen vs Google Gemma-2B:轻量级模型中文理解能力对比

Qwen vs Google Gemma-2B:轻量级模型中文理解能力对比 1. 为什么轻量级模型正在成为新刚需 你有没有遇到过这样的情况:想在一台老笔记本、边缘设备或者低配云服务器上跑一个能说中文的AI助手,结果刚下载完模型就提示“内存不足”&#xff1…

作者头像 李华
网站建设 2026/5/28 16:12:06

UniApp日志系统的性能优化与并发控制实战

UniApp日志系统的性能优化与并发控制实战 在移动应用开发中,日志系统是开发者排查问题、分析用户行为的重要工具。对于基于UniApp框架开发的高频交互型应用(如电商、社交类App),日志系统的性能直接影响用户体验和问题排查效率。本…

作者头像 李华
网站建设 2026/5/29 10:11:15

RMBG-2.0在运维自动化中的应用:服务器监控截图智能处理

RMBG-2.0在运维自动化中的应用:服务器监控截图智能处理 1. 引言 想象一下这样的场景:凌晨三点,你的手机突然响起告警铃声。服务器集群出现异常,你需要立即查看监控截图进行分析。但当你打开监控系统,眼前却是几十张布…

作者头像 李华
网站建设 2026/5/29 22:04:29

夸克自动转存工具完全指南:从入门到精通的7个实用技巧

夸克自动转存工具完全指南:从入门到精通的7个实用技巧 【免费下载链接】quark-auto-save 夸克网盘签到、自动转存、命名整理、发推送提醒和刷新媒体库一条龙 项目地址: https://gitcode.com/gh_mirrors/qu/quark-auto-save 夸克网盘作为资源存储与分享的重要…

作者头像 李华