0

0

Linux 开机自启动服务失效但手动 systemctl start 能启动的原因

舞夢輝影

舞夢輝影

发布时间:2026-01-19 12:08:03

|

219人浏览过

|

来源于php中文网

原创

服务开机自启动失效但手动启动成功,主因是未启用、依赖未就绪、target不匹配或条件检查失败;需依次检查 systemctl is-enabled、依赖关系、默认target及Condition配置。

linux 开机自启动服务失效但手动 systemctl start 能启动的原因

服务开机自启动失效但手动 systemctl start 能成功,通常不是服务本身有问题,而是启动时机、依赖关系或启用状态未正确配置所致。

服务未被启用(enable)

这是最常见原因:服务单元文件存在且可运行,但未通过 systemctl enable 创建启动链接,导致系统启动时不触发该服务。

  • 检查是否启用:systemctl is-enabled 服务名,返回 enabled 才表示已设为开机启动
  • 若返回 disabledstatic,需执行:sudo systemctl enable 服务名
  • static 表示服务没有 [Install] 段,无法直接 enable,需确认是否本就不支持自启,或需配合其他服务触发

依赖的服务未就绪或启动失败

即使服务自身无误,若它依赖的其他服务(如网络、数据库、挂载点)尚未启动或启动失败,systemd 会跳过或延迟启动它,甚至静默失败。

北极象沉浸式AI翻译
北极象沉浸式AI翻译

免费的北极象沉浸式AI翻译 - 带您走进沉浸式AI的双语对照体验

下载
  • 查看依赖关系:systemctl list-dependencies --reverse 服务名,重点关注 Wants=Requires=After= 中的单元
  • 检查关键依赖是否正常启用并启动:systemctl is-active network.targetsystemctl is-active multi-user.target
  • 典型问题:服务依赖 network-online.target,但网络未真正就绪(如 DHCP 超时),可改用 network.target 或加 Wants=network-online.target + After=network-online.target 并确保 systemd-networkd-wait-online.service 已启用

启动目标(target)不匹配或未加入默认 target

systemd 根据默认 target(如 multi-user.target)启动对应 Wants 列表中的服务。若服务只被某个非默认 target(如 graphical.target)引用,而系统以 multi-user 模式启动,就不会拉起它。

  • 确认默认 target:systemctl get-default
  • 检查服务是否在该 target 的 Wants 列表中:systemctl show 服务名 | grep -E "WantedBy|Also=",再查对应 target 的 Wants=(如 systemctl show multi-user.target | grep Wants
  • 若服务 [Install] 段中 WantedBy= 不是当前默认 target,需调整或重新 enable(systemctl disable && systemctl enable

服务配置中设置了冲突的启动条件

某些条件限制会导致服务在启动阶段被跳过,例如环境变量缺失、路径不存在、或 ConditionPathExists= 等判断失败。

  • 查看完整启动日志:journalctl -b -u 服务名,特别留意 Condition check 相关行
  • 常用条件指令:ConditionPathExists=ConditionFileIsExecutable=ConditionKernelCommandLine=ConditionUser= 等,任一为 false 即跳过启动
  • 临时绕过条件调试:启动时加 --no-block --no-ask-password 无效;应改用 systemctl start --no-block 服务名 对比行为,或注释掉 Condition 行测试

相关专题

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

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

220

2023.12.07

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

349

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2074

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

347

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

323

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

410

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

398

2023.10.16

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

3

2026.01.19

热门下载

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

精品课程

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

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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