首页 > 运维 > linux运维 > 正文

如何在Linux中禁止服务启动 Linux systemctl mask锁定

P粉602998670
发布: 2025-08-19 11:40:02
原创
483人浏览过
使用 systemctl mask 命令可彻底禁止服务启动,它通过将服务链接到 /dev/null 使其无法被加载或执行,比 disable 更彻底,disable 仅禁用开机自启但仍允许手动启动。

如何在linux中禁止服务启动 linux systemctl mask锁定

要在Linux中彻底禁止一个服务启动,甚至阻止它被手动启动,最可靠且推荐的方法是使用

systemctl mask
登录后复制
命令。它通过将服务的单元文件符号链接到
/dev/null
登录后复制
来实现“掩蔽”效果,让系统无法找到并启动该服务。

解决方案

禁止服务启动,特别是那些你确定不需要,甚至可能造成安全隐患或资源浪费的服务,

systemctl mask
登录后复制
是一个非常强力的工具。它比
systemctl disable
登录后复制
更进一步,后者只是阻止服务在系统启动时自动运行,但你依然可以手动启动它。而
mask
登录后复制
则是釜底抽薪,无论你尝试手动还是自动启动,系统都会因为找不到真正的服务文件而拒绝执行。

要使用它,命令很简单:

sudo systemctl mask <服务名称>
登录后复制

例如,如果你想彻底禁用一个名为

example.service
登录后复制
的服务:

sudo systemctl mask example.service
登录后复制

执行后,你会发现即使你尝试

sudo systemctl start example.service
登录后复制
,系统也会告诉你服务已被掩蔽。

如果将来你需要重新启用这个服务,或者只是想解除它的“掩蔽”状态,可以使用

unmask
登录后复制
命令:

sudo systemctl unmask <服务名称>
登录后复制

sudo systemctl unmask example.service
登录后复制

这会移除指向

/dev/null
登录后复制
的符号链接,让服务单元文件恢复正常,之后你就可以像往常一样
enable
登录后复制
start
登录后复制
它了。

systemctl mask
登录后复制
systemctl disable
登录后复制
有何不同?

说真的,这个问题经常困扰初学者,甚至一些老手有时也会混淆。我个人觉得,理解它们的根本差异,是管理Systemd服务的关键一步。

systemctl disable
登录后复制
的作用是阻止服务在系统启动时自动运行。它通常通过在
/etc/systemd/system/multi-user.target.wants/
登录后复制
或其他
.wants
登录后复制
目录中移除服务的符号链接来实现。这意味着,服务不会随系统开机启动,但如果你需要,完全可以通过
sudo systemctl start <服务名称>
登录后复制
手动启动它。这就像是把一个应用的“开机自启”选项关掉了。

systemctl mask
登录后复制
则完全不同。它将服务的单元文件直接符号链接到
/dev/null
登录后复制
。这意味着,当Systemd尝试查找并加载这个服务单元文件时,它找到的只是一个空洞的“黑洞”。无论你是想让它开机自启,还是手动敲命令
start
登录后复制
它,Systemd都会因为找不到真正的服务定义而拒绝执行。这就像是直接把应用程序的执行文件删掉了一样,你根本没法运行它。在我看来,
mask
登录后复制
更像是一种“永久禁止”或“彻底移除”的策略,适用于那些你明确知道永远不需要,或者出于安全考虑必须完全禁用的服务。比如,某些你觉得可能被滥用的调试服务,或者在你看来完全多余的系统组件。

如何查看已被
mask
登录后复制
的服务列表?

想要知道系统中有哪些服务被你“掩蔽”了,这其实挺重要的,尤其是在排查问题或者回顾配置的时候。毕竟,你可能不记得之前对哪些服务动过手脚。最直接的方法是查看服务的状态,如果一个服务被

mask
登录后复制
了,
systemctl status
登录后复制
命令会明确告诉你。

比如,如果你想检查

example.service
登录后复制

如知AI笔记
如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如知AI笔记 27
查看详情 如知AI笔记

systemctl status example.service
登录后复制

输出中会有一行显示

Loaded: masked (/dev/null; bad)
登录后复制
或类似的字样,表明它已经被
mask
登录后复制
了。

但如果你想列出所有被

mask
登录后复制
的服务,那就要用到
systemctl list-unit-files
登录后复制
命令,并结合
grep
登录后复制
来筛选了:

systemctl list-unit-files --state=masked
登录后复制

这个命令会列出所有处于

masked
登录后复制
状态的单元文件,包括服务(
.service
登录后复制
)、套接字(
.socket
登录后复制
)等等。这能让你一览无余地看到哪些系统组件被你“锁”住了。我个人觉得,定期检查一下这个列表是个好习惯,特别是当你接手一台新的Linux服务器,或者对系统进行过大量调整之后。有时候,一些不经意的操作可能就导致了某个关键服务被误
mask
登录后复制
,然后排查起来会很头疼。

mask
登录后复制
了关键服务怎么办?

这绝对是每个Linux用户都可能遇到的“心跳骤停”时刻。我个人就经历过几次,手滑或者没搞清楚依赖关系,一不小心就把一些看似不重要,实则系统核心依赖的服务给

mask
登录后复制
了。结果就是系统启动异常,或者某些关键功能直接罢工。遇到这种情况,别慌,
systemctl mask
登录后复制
是可逆的。

恢复的命令是

systemctl unmask <服务名称>
登录后复制

sudo systemctl unmask <误mask的服务名称>
登录后复制

执行这个命令后,Systemd会移除之前创建的指向

/dev/null
登录后复制
的符号链接,让服务的原始单元文件重新生效。但请注意,
unmask
登录后复制
之后,服务并不会自动启动,也不会自动设置为开机自启。你可能还需要手动启动它:

sudo systemctl start <服务名称>
登录后复制

如果这个服务原本就需要开机自启,你还需要重新

enable
登录后复制
它:

sudo systemctl enable <服务名称>
登录后复制

关键在于,在执行

mask
登录后复制
操作之前,一定要非常清楚这个服务的具体作用以及它是否有其他服务依赖它。一个简单的
systemctl status <服务名称>
登录后复制
就能给你很多信息,比如它的描述、依赖关系等等。如果实在不确定,或者服务名称看起来就很核心(比如和网络、日志、文件系统相关的),最好还是先查阅一下文档,或者选择
disable
登录后复制
而不是
mask
登录后复制
。毕竟,
disable
登录后复制
的恢复成本要低得多,而且不至于让系统陷入无法启动的境地。

以上就是如何在Linux中禁止服务启动 Linux systemctl mask锁定的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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