Linux启动流程为:固件POST→GRUB2加载内核与initramfs→内核初始化并用initramfs挂载真实根文件系统→systemd作为PID 1启动服务→呈现登录界面;现代主流采用UEFI+GPT+GRUB2+systemd组合。

Linux系统启动从按下电源键到出现登录界面,是一条环环相扣的链路。核心逻辑是:固件交出控制权 → 引导程序加载内核 → 内核借助initramfs挂载真实根文件系统 → systemd作为PID 1接管并启动服务 → 最终呈现用户空间。整个过程现代主流已全面转向UEFI + GPT + GRUB2 + systemd组合。
通电后,CPU跳转至固件(ROM/Flash)起始地址执行。BIOS或UEFI首先完成加电自检(POST),检测CPU、内存、存储控制器、键盘等基础硬件。若失败,通常停在自检界面或发出蜂鸣声。
随后按启动顺序(Boot Order)查找可引导设备:
当前新服务器、笔记本及云平台默认使用UEFI,支持GPT分区表(突破2TB限制)、更快启动、图形化菜单和网络引导能力。
GRUB2不直接编辑/boot/grub2/grub.cfg(该文件由grub2-mkconfig自动生成),而是通过修改/etc/default/grub来定制行为,例如设置默认启动项、超时时间或内核参数。
关键动作包括:
GRUB2在BIOS下分Stage1(MBR)、Stage1.5(文件系统驱动)、Stage2(完整功能);UEFI下则以单一.efi模块运行,结构更简洁。
内核被加载后立即解压自身,初始化中断、内存管理、调度器、设备驱动框架等核心子系统。此时它尚不能直接访问真实根文件系统——因为所需驱动(如NVMe、RAID、LVM、LUKS加密模块)可能以内核模块形式存于根分区中,形成“鸡生蛋”依赖。
initramfs正是为解决此问题而设计:
切换完成后,内核执行真实根下的/sbin/init(在systemd时代即指向/usr/lib/systemd/systemd)。
systemd作为PID 1进程,承担传统init的所有职责,并引入单元(Unit)模型统一管理服务、挂载点、套接字、定时器等资源。
启动流程实质是按依赖关系递归激活默认target(target即运行级别抽象):
登录管理器(如gdm、sddm)作为graphical.target的一部分被拉起,最终呈现TTY或桌面会话。
以上就是Linux系统启动流程是怎样的_BIOS到systemd完整解析【教程】的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号