0

0

Linux系统初始化过程_sysinit与服务加载说明【教程】

冰川箭仙

冰川箭仙

发布时间:2025-12-31 10:14:02

|

899人浏览过

|

来源于php中文网

原创

Linux系统启动不存在\_sysinit标准阶段,现代systemd发行版已弃用/etc/rc.d/rc.sysinit;其功能由local-fs.target、cryptsetup.target、systemd-udevd.service等unit按依赖关系并行实现。

linux系统初始化过程_sysinit与服务加载说明【教程】

Linux 系统启动时没有一个叫 _sysinit 的标准阶段或脚本——这是常见误解,多源于对旧版 SysV init 或某些定制发行版(如早期 CentOS 5/6)中 /etc/rc.d/rc.sysinit 的误传或混淆。现代主流发行版(RHEL 7+、Ubuntu 16.04+、Debian 8+)已全面采用 systemd,_sysinit 不再存在,也不应出现在配置或排错思路中。

为什么找不到 /etc/rc.d/rc.sysinit?

因为该文件只存在于 SysV init 时代(RHEL/CentOS 6 及更早),且它本身不是“系统级初始化函数”,而是一个 shell 脚本,负责挂载文件系统、启动 udev、设置主机名等基础任务。systemd 启动流程中,这些工作由多个 unit 文件并行完成,例如:

  • systemd-remount-fs.service 替代了文件系统重挂载逻辑
  • systemd-udev-settle.service(已弃用)和 systemd-udevd.service 处理设备节点
  • systemd-sysusers.servicesystemd-tmpfiles-setup.service 初始化系统用户与临时路径

如果你在 RHEL 8、AlmaLinux 9 或 Ubuntu 22.04 上执行 ls /etc/rc.d/rc.sysinit,会得到 “No such file or directory” —— 这是正常的,不是环境损坏。

systemd 中哪些 unit 实际承担了传统 sysinit 职责?

查看启动依赖链最直接的方式是运行:

systemctl list-dependencies --before sysinit.target

但注意:sysinit.target 在 systemd 中只是一个**同步锚点**(ordering target),不运行任何代码,仅用于保证基础服务(如 local-fs.targetswap.targetcryptsetup.target)在它之前启动。真正干活的是它的前序 targets 和 services:

BgSub
BgSub

免费的AI图片背景去除工具

下载
  • local-fs.target:要求所有本地文件系统(非网络、非 swap)已挂载完毕
  • cryptsetup.target:确保 LUKS 加密卷已解密并可用
  • systemd-journald.service:日志守护进程必须尽早启动,否则早期 boot 日志会丢失
  • systemd-udevd.service:设备事件处理核心,影响后续模块加载和硬件识别

这些 service 的启动顺序由 Wants=After=Conflicts= 控制,而非脚本执行顺序。

排查服务未按预期加载的常见陷阱

很多运维人员以为“服务没起来”是因为没加到 sysinit 阶段,实则问题常出在 unit 依赖定义错误或目标状态不满足:

  • 自定义 service 使用 After=network.service,但未声明 Wants=network.service → network 可能根本没启动,导致依赖悬空
  • 服务需要访问 /mnt/data,但 unit 中只写了 After=local-fs.target,未加 RequiresMountsFor=/mnt/data → 即使 local-fs.target 完成,该路径仍可能未挂载
  • 写了一个 sysinit.target.wants/xxx.service 符号链接,但 systemd 会忽略该目录 —— 正确做法是通过 systemctl enable xxx.service,它会自动链接到对应 target 的 wants 目录(如 multi-user.target.wants/
  • 使用 Type=oneshot 但忘了加 RemainAfterExit=yes → systemd 认为服务“退出即失败”,不会标记为 active

验证实际加载顺序可运行:systemd-analyze plot > boot.svg,用浏览器打开 SVG 查看各 service 的启动时间线与依赖关系。

真正要关注的不是“sysinit 怎么写”,而是每个 service 的 [Unit] 段是否准确表达了它对文件系统、设备、网络、其他服务的实际依赖。依赖写错比脚本漏执行更难排查,因为没有报错,只有行为异常。

相关专题

更多
磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1345

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

698

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

293

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

773

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

544

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

296

2023.07.20

linux查看cpu使用率
linux查看cpu使用率

在linux的系统维护中,可能需要经常查看cpu使用率,分析系统整体的运行情况。本专题为大家带来了linux查看cpu使用率的相关文章,感兴趣的朋友千万不要错过了。

374

2023.07.25

桌面文件位置介绍
桌面文件位置介绍

本专题整合了桌面文件相关教程,阅读专题下面的文章了解更多内容。

0

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.3万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号