centos7 systemctl添加自定义服务

详细的内容与原理请在本站点搜索Centos7 systemd整理,本文章只介绍常见的使用方法

背景

centos7开机第一个程序从init完全换成了systemd这种启动方式,同centos5和centos6已经存在实质差别。
systemd是靠管理unit的方式来控制开机服务,开机级别等功能。 在/usr/lib/systemd/system目录下包含了各种unit文件,有.service的服务unit,有.target的开机级别unit等,这里仅仅介绍关于.service后缀的文件。
因为systemd在开机要想执行自启动,都是通过这些*.service的unit控制的,服务又分为

  1. 系统服务:system,开机不登陆就能运行的程序,常用于开机自启
  2. 用户服务:user,需要登陆以后才能运行的程序

配置文件说明

.service的unit的配置文件中主要分为3大区块,每个区块都有自己的参数,下面是这些区块常用参数的说明:

[Unit] 区块(启动顺序与依赖关系)

  1. Description:当前服务的简单描述
  2. Documentation:说明文档位置
  3. After:此服务需要在哪些服务启动之后再启动,例如sshd.service启动之前需要先启动network.target需要启动,那么此处填写为network.target
  4. Before:此服务需要在哪些服务启动之前启动,例如sshd.service启动之后需要启动sshd-keygen.service,那么此处填写sshd-keygen.service
  5. Wants:表示弱依赖关系,即sshd-keygen.service启动失败或停止运行,也不影响sshd.service继续执行
  6. Requires:表示强依赖关系,即如果该服务启动失败或异常退出,那么sshd.service也必须退出

【注】:After和Before字段只涉及启动顺序,不涉及依赖关系;而Wants与Requires字段只涉及依赖关系,与启动顺序无关,默认情况下是同时启动的

[Service] 区块(启动行为)

启动类型

Type字段定义启动类型。它可以设置的值如下:

  1. simple:(默认值)ExecStart字段启动的进程为主进程
  2. forking:ExecStart字段将以fork()方式启动,此时父进程将会退出,子进程将成为主进程(后台运行)
  3. oneshot:类似于simple,但只执行一次,工作完毕之后就关闭,不会常驻于内存
  4. dbus:类似于simple,但会等待D-Bus信号后启动设置此项目是需要设置BusName这个参数的
  5. notify:类似于simple,启动结束后会发出通知信号,然后systemd再启动其他服务
  6. idle:类似于simple,但是要等到其他任务都执行完,才会启动该服务使用场合:为让该服务的输出,不与其他服务的输出相混合

启动命令

  1. ExecStart:启动服务时执行的命令必须使用绝对路径
  2. ExecReload:重启服务时执行的命令必须使用绝对路径
  3. ExecStop:停止服务时执行的命令必须使用绝对路径
  4. ExecStartPre:启动服务之前执行的命令
  5. ExecStartPost:启动服务之后执行的命令
  6. ExecStopPost:停止服务之后执行的命令

【注】:所有的启动设置之前,都可以加上一个连词号(-),表示抑制错误,即发生错误的时候,不影响其他命令的执行。比如EnvironmentFile=-/etc/sysconfig/sshd(注意等号后面的那个连词号),就表示即使/etc/sysconfig/sshd文件不存在,也不会抛出错误

重启行为

  1. KillMode:定义systemd如何停止服务
    1. control-group:(默认值)当前控制组里面的所有子进程,都会被杀掉
    2. process:只杀主进程
    3. mixed:主进程将收到SIGTERM信号,子进程收到SIGKILL信号
    4. none:没有进程会被杀掉,只是执行服务的stop命令
  2. Restart:定义了服务退出后,systemd的重启方式
    1. no(默认值):退出后不会重启
    2. on-success:只有正常退出时(退出状态码为0),才会重启
    3. on-failure:非正常退出时(退出状态码非0),包括被信号终止和超时,才会重启常用于守护进程
    4. on-abnormal:只有被信号终止和超时,才会重启常用于那些允许发生错误而退出的服务
    5. on-abort:只有在收到没有捕捉到的信号终止时,才会重启
    6. on-watchdog:超时退出,才会重启
    7. always:不管是什么退出原因,总是重启
  3. RestartSec:重启服务之前需要等待的秒数

[Install] 区块(定义如何安装这个配置文件,即怎样做到开机启动)

WantedBy:表示该服务所在的Target,Target的含义是服务组,表示一组服务。
例如WantedBy=multi-user.target指的是该服务所在的Target是multi-user.target,即多用户组。
这个设置非常重要,因为执行systemctl enable sshd.service命令时,sshd.service的一个符号链接,就会放在/etc/systemd/system目录下面的multi-user.target.wants子目录之中
systemd有默认的启动Target,可以使用命令systemctl get-default查看,一般默认为multi-user.target,在这个组里的所有服务,都将开机启动,这就是为什么systemctl enable命令能设置开机启动的原因。
使用Target的时候,有2个很有帮助的命令
systemctl list-dependencies命令和systemctl isolate命令也很有用,

  1. 查看multi-user.target包含的所有服务:systemctl list-dependencies multi-user.target
  2. 切换到另一个 target:systemctl isolate shutdown.targetshutdown.target就是关机状态

一般来说,常用的Target有两个:

  1. multi-user.target:表示多用户命令行状态
  2. graphical.target:表示图形用户状态,它依赖于multi-user.target

举例说明

  1. 配置文件目录:
    1. systemctl脚本目录:/usr/lib/systemd/
    2. 系统服务目录:/usr/lib/systemd/system/
    3. 用户服务目录:/usr/lib/systemd/user/
  2. 在/usr/lib/systemd/system目录下新建test.service文件:
[UNIT]
#服务描述
Description=Test Service
#指定了在systemd在执行完那些target之后再启动该服务
After=network.target

[Service]
#定义Service的运行类型
Type=simple
#定义systemctl start|stop|reload *.service 的执行方法(具体命令需要写绝对路径)
#注:ExecStartPre为启动前执行的命令
ExecStartPre=/usr/bin/test.sh
ExecStart=/home/mobileoa/apps/shMediaManager.sh -start
ExecReload=
ExecStop=

#创建私有的内存临时空间
PrivateTmp=True

[Install]
#多用户
WantedBy=multi-user.target
  1. 操作服务
    1. 重载系统服务:systemctl daemon-reload修改完配置文件要重载配置文件
    2. 设置开机启动:systemctl enable test.service
    3. 启动服务:systemctl start test.service
    4. 停止服务:systemctl stop test.service
    5. 重启服务:systemctl restart test.service