0

0

Linux 服务依赖关系分析方法

冷漠man

冷漠man

发布时间:2026-02-22 20:02:03

|

462人浏览过

|

来源于php中文网

原创

systemctl list-dependencies 仅显示单元文件中显式声明的 wants=、requires=、after=、before= 关系,不包含运行时动态依赖;需用 --all、--reverse、ldd、strace、journalctl 和 systemd-analyze 等工具分层排查四类依赖。

linux 服务依赖关系分析方法

systemctl list-dependencies 能看到哪些依赖

它只显示 systemd 单元(servicetargetsocket 等)在单元文件中显式声明的 Wants=Requires=After=Before= 关系,不反映运行时动态加载的模块、共享库或配置文件依赖。

实操建议:

  • --all 参数展开全部层级(默认只显示一级):systemctl list-dependencies --all sshd.service
  • --reverse 查谁依赖某个服务(比如查谁拉起了 docker.service):systemctl list-dependencies --reverse --all docker.service
  • 注意 WantedBy=multi-user.target 这类“反向依赖”不会出现在正向 list-dependencies 输出里,得靠 --reverse

ldd 和 strace 能补上哪些 systemd 看不见的依赖

systemd 不管二进制本身依赖什么库,也不管启动后打开哪些文件或 socket。这时候 lddstrace 是真实世界里的“照妖镜”。

常见错误现象:服务明明 systemctl start 成功,但日志里报 No such file or directorycannot open shared object file —— 很可能缺的是 .so 或配置路径。

实操建议:

  • 先定位主程序路径:systemctl show -p ExecStart sshd.service | grep ExecStart,再对二进制跑 ldd /usr/sbin/sshd
  • 快速抓启动时的文件访问:strace -e trace=openat,openat2,stat -f systemctl start myapp.service 2>&1 | grep -E "(No such|Permission denied|failed)"
  • strace 输出里出现 /etc/myapp/config.yaml: No such file,说明 systemd 启动成功只是“进程起来了”,但业务逻辑卡在读配置

journalctl -u + 配置文件路径是验证依赖链的关键证据

很多服务依赖不是写死在单元文件里的,而是由环境变量、外部配置或上游服务状态间接决定的。这时候日志和配置才是最终判决依据。

大师兄智慧家政
大师兄智慧家政

58到家打造的AI智能营销工具

下载

使用场景:服务启动失败,systemctl status 只显示 failed,但没说为什么;或者它启动了,但功能异常。

实操建议:

  • 查完整启动过程:journalctl -u nginx.service --since "1 hour ago" -n 100,重点看 execv 行和第一条 ERROR
  • 确认实际加载的配置:nginx -thttpd -t,它们会打印出真正被读取的 .conf 路径,而不是你以为的 /etc/nginx/nginx.conf
  • 如果服务依赖另一个服务提供的 socket(如 php-fpm.sock),检查该 socket 是否存在且权限正确:ls -l /run/php/php-fpm.sockgetenforce 结果为 Enforcing 时 SELinux 可能拦截访问

systemd-analyze verify 和 dot 导出适合排查循环依赖和拼写错误

systemctl daemon-reload 没报错,但服务启不动,或者 list-dependencies 输出里出现可疑的重复项,大概率是单元文件里写错了名字,或者 After=Before= 形成闭环。

性能影响:循环依赖会导致 systemd 卡住,超时后报 Job for xxx.service cancelled,而不是明确的错误提示。

实操建议:

  • 检查语法和命名:systemd-analyze verify /etc/systemd/system/myapp.service,它会指出 Wants=nonexistent.service 这类拼写错误
  • 导出依赖图看结构:systemd-analyze dot 'myapp.service' | dot -Tpng > deps.png,用图像工具打开,一眼识别双向箭头或长链
  • 注意 dot 默认不包含 target 单元,加 --to-pattern="*.target" 才能看到完整启动目标路径

真正的难点不在命令怎么敲,而在于分清“声明的依赖”“链接的依赖”“运行时的依赖”和“配置触发的依赖”——这四层叠在一起,漏掉任何一层,排查就会绕远路。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

518

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

567

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

242

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

561

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3606

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

49

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

67

2026.01.13

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1030

2026.02.13

热门下载

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

精品课程

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

共48课时 | 9.5万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

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

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