0

0

Linux systemd 服务依赖关系解析

冰川箭仙

冰川箭仙

发布时间:2026-02-04 21:41:02

|

553人浏览过

|

来源于php中文网

原创

绝大多数场景应使用 Wants 而非 Requires;Wants 是软依赖,目标失败不影响本服务启动,Requires 是硬依赖,目标失败将导致本服务进入 failed 状态,且两者均需配合 After/Before 才能控制启动顺序。

linux systemd 服务依赖关系解析

systemd 服务依赖用 Wants 还是 Requires?

WantsRequires 都声明依赖,但行为完全不同:前者只“希望”目标服务启动,失败也不影响本服务;后者则强制要求目标服务必须成功启动,否则本服务直接失败并进入 failed 状态。实际写单元文件时,绝大多数场景该用 Wants ——比如 Web 服务想等网络就绪,用 Wants=network-online.target 更健壮;若误写成 Requires,只要 systemd-networkd-wait-online.service 超时(默认 90 秒),你的服务就起不来。

  • Requires 触发硬依赖,会阻塞本服务的 start 流程
  • Wants 是软依赖,目标服务启动失败或未定义,本服务照常运行
  • 两者都不隐含启动顺序控制,需配合 AfterBefore 使用

After 和 Before 不等于依赖,漏写 Wants/Requires 就白配

After=redis-server.service 只表示“我比 redis 启动晚”,但如果 redis 没被其他服务激活、也没设为开机启动,它根本不会启动——你的服务就会卡在“等待一个永远不会出现的时机”。常见错误是只写 After,结果服务启动时报 Job for xxx.service failed because a dependency job failed,日志里却看不到 redis 的任何启动记录。

  • 必须成对使用:Wants=redis-server.service + After=redis-server.service
  • After 不触发目标服务启动,仅排序;Wants 才真正拉起依赖
  • 若目标服务是 target(如 multi-user.target),Wants 通常已由系统预设,此时只补 After 即可

如何查清某个服务实际依赖了哪些单元?

别信文档或猜测,用 systemctl list-dependencies --reverse xxx.service 看谁依赖它;用 systemctl list-dependencies --all xxx.service 看它自己依赖了哪些(含间接依赖)。注意默认只显示 active 单元,加 --all 才能看到所有声明的依赖,包括那些没启用、甚至不存在的单元。

ExcelFormulaBot
ExcelFormulaBot

在AI帮助下将文本指令转换为Excel函数公式

下载
  • list-dependencies 输出的是解析后的依赖图,不是原始 unit 文件内容
  • 如果某依赖显示为 not-found,说明 unit 文件写了 Wants=xxx 但系统里没有这个单元(拼错名、包未安装)
  • 依赖链过深时,加 --depth=3 控制层数,避免刷屏

循环依赖检测不到?systemd 其实有静默截断机制

systemd 在加载 unit 文件阶段会检测显式循环(如 A Wants=B 且 B Wants=A),报错退出。但更常见的是隐式循环:A Wants=B + After=C,而 C 又通过 Requires 间接拉起 A。这种情况下 systemd 不报错,而是按加载顺序“截断”依赖链,导致部分 After 失效、启动顺序错乱。

  • 日志中可能只出现 Found ordering cycle 提示,不中断启动,但行为不可预测
  • 推荐用 systemd-analyze verify xxx.service 主动检查(需 systemd v245+)
  • 真实环境中,跨团队维护的服务最容易踩这类坑——A 团队加 After,B 团队加 Wants,没人通盘看依赖图

真实依赖关系不是靠“觉得应该等”来写的,得从启动日志倒推、用 list-dependencies 验证、再用 verify 扫描潜在环。很多看似随机的启动失败,根源都在某一行漏掉的 Wants 或多写的 Requires

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

986

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

644

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

488

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

404

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

397

2024.04.07

mysql和redis怎么保证双写一致性
mysql和redis怎么保证双写一致性

确保 mysql 和 redis 双写一致性的技术包括:1、事务性更新:同时更新 mysql 和 redis,保证一致性;2、主从复制:mysql 主服务器更改同步到 redis 从服务器;3、基于事件的更新:mysql 记录更改并发送到 redis等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

458

2024.04.07

redis缓存一般存些什么数据
redis缓存一般存些什么数据

redis缓存中存储的数据类型包括:字符串、哈希、列表、集合、有序集合、位图、地理空间数据和hyperloglog。这些数据类型适用于存储各种数据,从简单信息到复杂对象和地理位置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

410

2024.04.07

redis的8种数据类型有哪些
redis的8种数据类型有哪些

redis 提供 8 种数据类型:字符串(文本、数字、二进制)、哈希(键值对)、列表(有序集合)、集合(无序唯一元素)、有序集合(按分数排序)、地理空间(地理位置)、hyperloglog(估计大数据基数)和位图(位序列存储)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

435

2024.04.07

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

61

2026.02.04

热门下载

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

精品课程

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

共48课时 | 8.5万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

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

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