Loading

Systemd 配置服务管理

原创转载:https://blog.csdn.net/qq_41084756/article/details/130200523

1:Systemd 案例

systemd 是 Linux 系统中现代化的初始化系统,可以使用 systemctl 命令实现管理 启动、关闭、自启动 等服务。

在systemd中,可以通过创建一个service文件,把要执行的命令放在其中,然后将其添加到systemd的自启动项中。

具体操作步骤如下:

0x01:在 /etc/systemd/system 目录下创建一个.service 文件。

# 注意 service 文件的名字也是 systemd 启动的名字,例如 systemctl start myservice
vim /etc/systemd/system/myservice.service

0x02:编写.service 文件。

# 在打开的文件中添加以下内容,注意将其中的 ExecStart 替换为需要管理的命令或脚本
[Unit]
Description=My Service
After=network.target

[Service]
Type=simple
ExecStart=sudo /path/to/my/command
User=root

[Install]
WantedBy=multi-user.target

0x03:以下是 service 文件中出现的参数解释。

Unit: systemd服务文件的一个部分,用于定义服务的基本信息。

  • Description字段包含了一个简短的描述,用于描述服务的名称,方便用户在查找时快速了解服务的作用。
  • After=network.target表示此服务会在网络服务启动后启动。
    • network.target是指网络目标单元,是Systemd中预定义的一个特殊单元,用于表示网络服务的启动状态。几乎所有的网络服务,例如DHCP、DNS解析等,在启动时都依赖于网络服务的可用性。因此,将After=network.target添加到服务的unit文件中,可以确保该服务在网络服务就绪后再启动,从而避免出现启动时的依赖性错误。

Service: 是systemd服务文件中的另一个部分,用于定义服务的具体行为。

  • Type字段是服务运行时的类型,simple表示它是一个后台进程,通常用于只有一个进程的服务。
  • ExecStart字段包含了要运行的命令,多个命令可以用换行符(\n)隔开。
  • User字段指定了以哪个用户的身份运行这个服务,这里选择root用户。

Install: 定义了systemd服务的安装信息。

  • WantedBy字段指定了服务将要执行的“target”(一种操作系统运行级别),这里指定的“multi-user.target”是Linux系统默认的、包含多个用户的运行级别,相当于传统的“init 3”运行级别。这意味着服务将在系统启动时自动运行。

2:Systemd 命令

# 保存并退出上述 Systemd 案例,启动服务&系统自启动  
systemctl start myservice
systemctl enable myservice

# 使用 systemctl命令查看服务状态: 
systemctl status myservice.service

# 关闭服务&系统关闭自启动
systemctl stop myservice
systemctl disable myservice

3:Systemd 文件

3.1:介绍

Systemd 服务文件通常存放在 /etc/systemd/system 目录下。

Systemd 服务文件通常是以 .service 结尾的文本文件。

服务文件中的格式类似 .ini 配置文件的格式,以 字段 + 键值对 的形式组成。

3.2:字段

Systemd 服务文件通常包含了以下 [字段],每个字段下可配置多个键值对。

配置项 作用
Unit 服务的全局信息和依赖性声明,如服务名称、描述等。
Service 指定服务的具体配置,如服务执行的命令、工作目录等。
Instal 指定服务的安装方式,如服务的启动级别等。

3.3:键值对

0x01:[Unit] 字段的配置

Key Value
Description 对服务的简短描述。
Before 定义服务在其他服务之前启动。
After 定义服务在其他服务之后启动。
Requires 定义服务启动需要哪些其他服务已启动,否则无法启动。
PartOf 定义该服务是其他服务的一部分,如果其他服务停止,该服务也会停止。
Wants 定义服务启动时可同时启动哪些其他服务。
Condition... 定义服务启动的条件,如 ConditionPathExists 表示某个路径存在时才启动该服务。

0x02:[Service] 字段的配置

Key Value
Type 服务类型,可以是simple、forking、ondemand、notify等。
ExecStart 服务启动命令,可以是单个命令、脚本文件、或者多个命令组成的脚本。
ExecStop 停止服务的命令。
User 定义服务运行的用户。
Group 定义服务运行的用户组。
PrivateTmp 将服务的/tmp目录挂载到私有的命名空间中,以增强安全性。
Restart 定义服务异常退出时如何重启。
WorkingDirectory 定义服务工作目录。
Environment 定义服务的环境变量等。
ProtectSystem 防止服务对系统文件进行修改。
NoNewPrivileges 防止服务通过setuid或setgid等提升权限。

0x03:[Install] 字段的配置

Key Value
WantedBy 定义在哪些系统运行级别下启用此服务。
RequiredBy 启动其他系统服务时必需启动此服务。

3.4:示例

这个示例中定义了一个名为"MyService"的服务,服务启动时执行 /usr/bin/myservice 命令,执行工作目录为 /var/myservice,运行用户为 myservice。

如果服务异常退出,则每30秒尝试重新启动,最多尝试3次。

最后,服务将在多用户运行级别下启用。

[Unit]
Description=MyService
After=network.target
  
[Service]
Type=simple
ExecStart=/usr/bin/myservice
WorkingDirectory=/var/myservice
User=myservice
Group=myservice
Restart=always
RestartSec=30
StartLimitInterval=400
StartLimitBurst=3
  
[Install]
WantedBy=multi-user.target
posted @ 2024-06-05 19:15  忽如一夜春风来~  阅读(101)  评论(0编辑  收藏  举报