用户自定义的 systemd unit 文件应该放在哪里?

/usr/lib/systemd/system//etc/systemd/system/ 都是存放 systemd unit 文件的地方,但它们之间存在重要的区别。理解这些区别对于管理和配置你的系统至关重要。


/usr/lib/systemd/system/ vs /etc/systemd/system/

特性 /usr/lib/systemd/system/ /etc/systemd/system/
用途 存放发行版(distribution)提供的默认 unit 文件。 存放系统管理员(system administrator)或用户自定义的 unit 文件。
所有者 属于操作系统或软件包管理器(如 dnf, apt 等)管理。 属于系统管理员手动创建和管理。
更新 当你更新软件包时,这个目录下的文件可能会被覆盖 这个目录下的文件不会被系统更新覆盖。
优先级 优先级较低 优先级较高 。如果 /etc/systemd/system/ 中存在与 /usr/lib/systemd/system/ 同名的文件,systemd 会优先使用 /etc/systemd/system/ 中的文件。
可修改性 不建议手动修改。任何修改都可能在系统更新后丢失。 可以自由创建、修改和删除。
示例 系统服务,如 sshd.service, dbus.service 等。 用户自定义的服务,如你自己的 Web 应用服务、数据库服务等。

简单来说,/usr/lib/systemd/system/ 是系统的默认配置 ,由操作系统维护,你不应该去修改它。而 /etc/systemd/system/ 则是自定义配置 ,用于覆盖或扩展默认配置。这种设计遵循了**配置分层(configuration layering)**的原则,确保系统配置的稳定性和可维护性。


用户自定义的 systemd unit 文件应该放在哪里?

用户自定义的 systemd unit 文件(包括你自己的服务、定时任务等)应该放在 /etc/systemd/system/ 目录下。

这样做有以下几个主要好处:

  1. 优先级保证:确保你的自定义服务配置能够覆盖或补充系统默认的服务。
  2. 防止更新覆盖:避免在系统更新或软件包升级时丢失你辛辛苦苦编写的 unit 文件。
  3. 清晰的管理:将你的个人或项目配置与系统默认配置分开,使管理更加清晰和安全。

如果你需要修改一个已有的系统服务(例如 sshd.service),但又不想直接修改 /usr/lib/systemd/system/sshd.service,你可以:

  • /etc/systemd/system/ 中创建一个同名的文件,例如 /etc/systemd/system/sshd.service,来覆盖原始文件。
  • 更推荐的方式是创建drop-in 目录 ,例如 /etc/systemd/system/sshd.service.d/,并在其中创建以 .conf 结尾的配置文件(例如 override.conf)。这种方法允许你只修改需要变更的配置项,而不是整个 unit 文件,从而使配置管理更加精细和模块化。

总而言之,记住 "/etc 优先于 /usr/lib" 的原则,并始终将你的自定义配置放在 /etc/systemd/system/ 及其子目录中。

相关推荐
万添裁16 小时前
1.Linux:命令提示符,history和常用快捷键
linux·运维·服务器
轻松Ai享生活16 小时前
怎么在5天内将Linux systemd学精通
linux
悲伤小伞17 小时前
Linux_网络基础
linux·服务器·c语言·网络
KingRumn18 小时前
Linux ARP老化机制/探测机制/ip neigh使用
linux·网络·tcp/ip
学生董格18 小时前
[嵌入式embed][Qt]Qt5.12+Opencv4.x+Cmake4.x_用Qt编译linux-Opencv库 & 测试
linux·qt·opencv
我要打打代码19 小时前
wpf触发器
java·linux·wpf
m0_5713728219 小时前
关于嵌入式学习——嵌入式硬件2
linux·驱动开发·嵌入式硬件·学习
Cold_Rain0219 小时前
Linux 用户的 Windows 改造之旅
linux·运维·windows
☆璇19 小时前
【Linux】Linux下基本指令
linux·运维·服务器