1.44. Centos7-systemd服务封装server.md

1.44.1. 1. systemd示例

示例1-supervisord

$  vim /usr/lib/systemd/system/supervisord.service
[Unit]
Description=Process Monitoring and Control Daemon
After=rc-local.service nss-user-lookup.target

[Service]
Type=forking
ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf
ExecReload=/usr/bin/supervisorctl reload
ExecStop=/usr/bin/supervisorctl shutdown

[Install]
WantedBy=multi-user.target

设置754权限

chmod 754 /usr/lib/systemd/system/supervisord.service
systemctl daemon-reload

示例2-banjo

$ cat banjo.service
[Unit]
Description=banjo - banjo rserver
After=network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
ExecStart=/app/oscbin/banjo/bin/banjo -D
ExecStop=/app/oscbin/banjo/bin/banjo -s stop
ExecReload=/app/oscbin/banjo/bin/banjo -s restart
PrivateTmp=true

[Install]
WantedBy=multi-user.target

设置权限

$ chmod 644 /usr/lib/systemd/system/banjo.service
$ systemctl daemon-reload

示例3-nginx_exporter

创建nginx_exporter目录,移动文件

$ mkdir -p /etc/nginx_exporter/bin/
$ mv /opt/nginx_exporter /etc/nginx_exporter/bin/

封装service

$ vim /lib/systemd/system/nginx_exporter.service

内容如下:

[Unit]
Description=nginx monitor
After=network.target

[Service]
ExecStart=/etc/nginx_exporter/bin/nginx_exporter -nginx.scrape_uri="http://127.0.0.1:8011/nginx_status"
ExecStop=-/sbin/start-stop-daemon --quiet --stop --retry QUIT/5
TimeoutStopSec=5
KillMode=mixed

[Install]
WantedBy=multi-user.target

重新加载service配置文件,设置开机自启动,并启动服务

$ systemctl daemon-reload
$ systemctl enable nginx_exporter.service
$ systemctl start nginx_exporter.service

查看端口

$ netstat -anpt|grep nginx_exporte
tcp        0      0 127.0.0.1:33780         127.0.0.1:8011          ESTABLISHED 19006/nginx_exporte
tcp6       0      0 :::9113                 :::*                    LISTEN      19006/nginx_exporte
tcp6       0      0 192.168.1.24:9113       172.17.0.2:50776        ESTABLISHED 19006/nginx_exporte

示例4-java_xx.sh

创建脚本

/usr/bin 目录下创建脚本,比如我的脚本名为 /usr/bin/ruoyi-gen.sh,内容如下:

#!/bin/bash
java -jar /root/xf-service/ruoyi-modules-gen-2.3.0.jar > /root/xf-service/ilogs/modules-gen-`date "+%Y-%m-%d"`.log 2>&1 &

然后为脚本设置执行权限 chmod +x /usr/bin/ruoyi-gen.sh

添加服务

编辑 /etc/systemd/system/ruoyi-gen.service 文件名最后跟你的服务相关,比如我的叫 ruoyi-gen。内容大体如下:

[Unit]
Description=ruoyi-gen
After=network.target ali-nacos.target ali-sentinel.target ruoyi-gateway.target ruoyi-auth.target

[Service]
Type=forking
ExecStart=/usr/bin/ruoyi-gen.sh

[Install]
WantedBy=multi-user.target

然后重载系统服务文件 systemctl daemon-reload

服务管理

# 启动
$ sudo systemctl start ruoyi-gen

# 查看状态
$ sudo systemctl status ruoyi-gen

# 停止服务
$ sudo systemctl stop ruoyi-gen

# 重启服务
$ sudo systemctl restart ruoyi-gen

#开机自启
$ sudo systemctl enable ruoyi-gen

配置文件介绍

[Unit]区块通常是配置文件的第一个区块,用来定义 Unit 的元数据,以及配置与其他 Unit 的关系。它的主要字段如下。

  • Description:简短描述

  • Documentation:文档地址

  • Requires:当前 Unit 依赖的其他 Unit,如果它们没有运行,当前 Unit 会启动失败

  • Wants:与当前 Unit 配合的其他 Unit,如果它们没有运行,当前 Unit 不会启动失败

  • BindsTo:与Requires类似,它指定的 Unit 如果退出,会导致当前 Unit 停止运行

  • Before:如果该字段指定的 Unit 也要启动,那么必须在当前 Unit 之后启动

  • After:如果该字段指定的 Unit 也要启动,那么必须在当前 Unit 之前启动

  • Conflicts:这里指定的 Unit 不能与当前 Unit 同时运行

  • Condition...:当前 Unit 运行必须满足的条件,否则不会运行

  • Assert...:当前 Unit 运行必须满足的条件,否则会报启动失败

[Install]通常是配置文件的最后一个区块,用来定义如何启动,以及是否开机启动。它的主要字段如下。

  • WantedBy:它的值是一个或多个 Target,当前 Unit 激活时(enable)符号链接会放入/etc/systemd/system目录下面以 Target 名 + .wants后缀构成的子目录中

  • RequiredBy:它的值是一个或多个 Target,当前 Unit 激活时,符号链接会放入/etc/systemd/system目录下面以 Target 名 + .required后缀构成的子目录中

  • Alias:当前 Unit 可用于启动的别名

  • Also:当前 Unit 激活(enable)时,会被同时激活的其他 Unit

[Service]区块用来 Service 的配置,只有 Service 类型的 Unit 才有这个区块。它的主要字段如下。

  • Type:定义启动时的进程行为。它有以下几种值。

  • Type=simple:默认值,执行ExecStart指定的命令,启动主进程

  • Type=forking:以 fork 方式从父进程创建子进程,创建后父进程会立即退出

  • Type=oneshot:一次性进程,Systemd 会等当前服务退出,再继续往下执行

  • Type=dbus:当前服务通过D-Bus启动

  • Type=notify:当前服务启动完毕,会通知Systemd,再继续往下执行

  • Type=idle:若有其他任务执行完毕,当前服务才会运行

  • ExecStart:启动当前服务的命令

  • ExecStartPre:启动当前服务之前执行的命令

  • ExecStartPost:启动当前服务之后执行的命令

  • ExecReload:重启当前服务时执行的命令

  • ExecStop:停止当前服务时执行的命令

  • ExecStopPost:停止当其服务之后执行的命令

  • RestartSec:自动重启当前服务间隔的秒数

  • Restart:定义何种情况 Systemd 会自动重启当前服务,可能的值包括always(总是重启)、on-successon-failureon-abnormalon-aborton-watchdog

  • TimeoutSec:定义 Systemd 停止当前服务之前等待的秒数

  • Environment:指定环境变量

Unit 配置文件的完整字段清单,请参考官方文档

1.44.2. 2. systemd自动生成工具

https://www.mogublog.net/app/systemd/

参考文献: