Linux系统启动流程解析_Linux从引导到登录的过程

2次阅读

linux启动过程分为四阶段:1. bios/UEFI初始化硬件并加载引导程序;2. GRUB2加载内核与initramfs;3. 内核解压、初始化并挂载initramfs执行/init;4. systemd启动服务链,最终运行显示管理器呈现登录界面。

Linux系统启动流程解析_Linux从引导到登录的过程

linux系统从按下电源键到出现登录界面,整个过程看似一气呵成,实则由多个阶段协同完成。理解这个流程,对排查启动故障、定制引导行为或优化系统响应都至关重要。

BIOS/UEFI固件初始化与硬件自检

通电后,CPU首先执行主板ROM中的固件代码(传统BIOS或现代UEFI)。它会进行加电自检(POST),检测内存、存储设备、显卡等关键硬件是否就绪,并根据启动顺序查找可引导设备(如硬盘u盘、网络)。UEFI还会加载安全启动策略并验证引导加载程序签名。

关键点:

  • BIOS模式下,MBR(前512字节)被读入内存并执行;UEFI模式下,固件直接加载EFI系统分区(ESP)中的.efi文件(如grubx64.efi
  • 可通过开机时按Del/F2/F12等键进入固件设置,调整启动顺序或禁用Secure Boot

引导加载程序(Bootloader)接管控制权

主流Linux发行版多使用GRUB2(Grand Unified Bootloader version 2)。它被安装在MBR或ESP中,负责加载内核和初始内存盘(initramfs)。GRUB启动后会显示菜单,允许用户选择内核版本、进入恢复模式或编辑启动参数。

常见操作:

  • 启动时按c键进入GRUB命令行,可手动指定内核和initramfs路径
  • e键临时编辑当前启动项,在linux行末尾添加rd.break可中断initramfs阶段用于密码重置
  • /boot/grub/grub.cfggrub-mkconfig生成,不建议直接修改

内核加载与initramfs解压执行

GRUB将vmlinuz(压缩的Linux内核镜像)和initramfs(初始根文件系统)载入内存并跳转执行。内核解压自身,初始化CPU、内存、中断、设备驱动等核心子系统。随后挂载initramfs为临时根文件系统,运行其中的/init脚本。

Linux系统启动流程解析_Linux从引导到登录的过程

OneStory

OneStory 是一款创新的ai故事生成助手,用AI快速生成连续性、一致性的角色和故事。

Linux系统启动流程解析_Linux从引导到登录的过程 319

查看详情 Linux系统启动流程解析_Linux从引导到登录的过程

initramfs的作用是:

  • 加载磁盘控制器、加密模块(如LUKS)、LVM或RAID驱动,以便访问真正的根分区
  • 探测并激活根设备(如/dev/sda2或UUID=…),然后切换到真实根文件系统(switch_root)
  • 若缺少必要驱动,系统会卡在“dracut”或“Failed to mount root”提示

用户空间启动:systemd初始化与登录管理器启动

内核通过execve()启动第一个用户进程——通常是/sbin/init,现代发行版默认指向systemd。systemd依据单元文件(.service、.target等)按依赖关系启动服务。

典型启动链路:

  • systemd启动default.target(通常软链接到graphical.target
  • 依次激活multi-user.target → getty.target → getty@tty1.service,最终启动gdm3(GNOME)、sddm(KDE)或lightdm等显示管理器
  • 显示管理器绘制图形登录界面,等待用户输入凭证

可通过systemctl list-units –type=target查看当前激活的目标,用journalctl -b查看本次启动日志。

基本上就这些。每个环节都有明确职责,任一阶段出错都会中断流程。掌握各阶段的关键组件和调试方法,能快速定位黑屏、卡LOgo、无法登录等问题根源。

text=ZqhQzanResources