0

0

Linux 服务启动顺序配置实战

冷炫風刃

冷炫風刃

发布时间:2026-02-04 16:49:03

|

904人浏览过

|

来源于php中文网

原创

systemd服务启动顺序依赖需用After=与Wants=/Requires=组合:After=仅表时序,Wants=为弱依赖,Requires=为强依赖;避免循环依赖;验证须用systemd-analyze critical-chain等命令查真实链路,而非仅看配置。

linux 服务启动顺序配置实战

systemd 服务启动顺序依赖怎么写

Linux 现在基本都用 systemd,控制启动顺序靠的是依赖关系,不是传统 SysV 的数字编号。写错依赖会导致服务起不来,或者起得太早——比如数据库还没监听,Web 服务就去连它,报 Connection refused

关键不是“谁先谁后”,而是“谁等谁”。用 After=Wants=(或 Requires=)组合才有效:

  • After=network.target 只表示时间先后,不保证网络已就绪;真要等网卡配好,得加 Wants=network-online.target + After=network-online.target
  • Requires=redis.service 表示强依赖:如果 redis.service 启动失败,本服务直接 abort,不会尝试启动
  • Wants=redis.service 是弱依赖:redis.service 启动失败不影响本服务继续,但本服务仍会在它之后启动(配合 After=
  • 避免循环依赖:A Wants=B + After=BB Wants=A + After=A 会让 systemd 拒绝加载单元文件,报错 Unit A has a dependency cycle with B

如何验证服务实际启动顺序

光看配置不顶用,得查真实执行流。最直接的方式是看启动时序图:

systemd-analyze plot > boot.svg

打开 boot.svg 就能看到所有服务横向排布、启动/结束时间轴。但更常用的是过滤关键服务:

  • systemd-analyze blame 查耗时最长的服务(常暴露隐性阻塞)
  • systemd-analyze critical-chain myapp.service 显示从 default.targetmyapp.service 的完整依赖链,每一步是否成功、耗时多少一目了然
  • journalctl -u myapp.service -u postgresql.service --since "1 hour ago" 对比日志时间戳,确认 PostgreSQL 是否真在 myapp.service 启动前 ready

注意:systemd-analyze 默认只分析上次 boot,重启后数据刷新,别拿旧结果当依据。

得推共享菜园系统
得推共享菜园系统

得推共享菜园系统是一款专门针对家共享菜园开发的,可以通过基地加盟,轻松实现共享菜园平台建设。系统可以支持wap\公众号\小程序\APP. 基本功能:基地管理、菜园分类、菜园订单、菜园维护、菜园动态等 管理后台: 1.网站设置:站点信息,支付配置,短信配置,邮箱配置等 2.账户管理:账户审核,实名认证,用户充值,黑名单等 3.订单管理:服务订单、确认、处理、退单

下载

自定义服务里误用 Type=forking 导致顺序错乱

很多老脚本习惯后台化(&daemonize=yes),写 unit 文件时就随手设 Type=forking。但 systemd 对它的识别很脆弱:

  • 必须严格指定 PIDFile=,且进程真要写这个文件;否则 systemd 认为服务“没起来”,后续依赖服务永远等不到它
  • 如果程序 fork 多次(比如 supervisord 起多个子进程),PIDFile 里写的可能不是主进程 PID,systemd 会误判状态
  • 推荐优先用 Type=simple(默认):只要主进程没 exit,就认为服务 running;适合现代 Go/Python 服务(不 daemonize,前台运行)
  • 实在要用 forking,务必加 TimeoutSec=(比如 TimeoutSec=60),防止 systemd 卡死等待一个永远不会出现的 PID 文件

容器或云环境里 network-online.target 不可靠

在 Docker、LXC、AWS EC2 等环境,network-online.target 经常假成功:网卡起来了,但 DHCP 还没回包、DNS 没通、甚至元数据服务(如 169.254.169.254)不可达。这时候硬等它,服务反而启动更慢甚至超时失败。

更稳妥的做法是让服务自己重试,而不是靠 systemd 等网络:

  • 去掉 Wants=network-online.target,改用 After=multi-user.target
  • 在服务启动命令里包装一层重试逻辑,比如:
    ExecStart=/usr/bin/sh -c 'until nc -z localhost 5432; do sleep 2; done && /usr/local/bin/myapp'
  • 或者用 systemd 原生的重启机制:Restart=on-failure + RestartSec=3,配合应用内连接池的重试,比外部等网络更健壮

真正难处理的不是“怎么配顺序”,而是“什么时候不该配顺序”——多数场景下,让服务自己应对依赖未就绪,比让 init 系统强行串行更可靠。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2023.12.07

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

263

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

503

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

405

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

445

2024.04.08

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

常用的数据库软件有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

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

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

22

2026.02.04

热门下载

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

精品课程

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

共48课时 | 8.4万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

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

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