Centos 7 systemctl启动脚本详解

Centos 7 systemctl启动脚本详解

标签:centos

环境介绍

  • centos 7
  • /usr/lib/systemd/system # 系统服务,开机不需要登录就能运行的程序(相当于开机自启)
  • /usr/lib/systemd/user # 用户服务,需要登录后才能运行的程序

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
vim /usr/lib/systemd/system/xxx.service 
[Unit] # 主要是服务说明
Description=test # 简单描述服务
After=network.target # 描述服务类别,表示本服务需要在network服务启动后在启动
Before=xxx.service # 表示需要在某些服务启动之前启动,After和Before字段只涉及启动顺序,不涉及依赖关系。

[Service] # 核心区域
Type=forking # 表示后台运行模式。
User=user # 设置服务运行的用户
Group=user # 设置服务运行的用户组
KillMode=control-group # 定义systemd如何停止服务
PIDFile=/usr/local/test/test.pid # 存放PID的绝对路径
Restart=no # 定义服务进程退出后,systemd的重启方式,默认是不重启
ExecStart=/usr/local/test/bin/startup.sh # 服务启动命令,命令需要绝对路径
ExecReload=/usr/local/test/bin/startup.sh #服务重启命令
ExecStop=/usr/local/test/bin/startup.sh #服务关闭命令
PrivateTmp=true # 表示给服务分配独立的临时空间
config.file/usr/local/xxxx.conf #指定配置文件

[Install]
WantedBy=multi-user.target # 多用户

详细参数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
Type的类型有:
simple(默认):# 以ExecStart字段启动的进程为主进程
forking: # ExecStart字段以fork()方式启动,此时父进程将退出,子进程将成为主进程(后台运行)。一般都设置为forking
oneshot: # 类似于simple,但只执行一次,systemd会等它执行完,才启动其他服务
dbus: # 类似于simple, 但会等待D-Bus信号后启动
notify: # 类似于simple, 启动结束后会发出通知信号,然后systemd再启动其他服务
idle: # 类似于simple,但是要等到其他任务都执行完,才会启动该服务。
KillMode的类型:
control-group(默认):# 当前控制组里的所有子进程,都会被杀掉
process: # 只杀主进程
mixed: # 主进程将收到SIGTERM信号,子进程收到SIGKILL信号
none: # 没有进程会被杀掉,只是执行服务的stop命令
Restart的类型:
no(默认值): # 退出后无操作
on-success: # 只有正常退出时(退出状态码为0),才会重启
on-failure: # 非正常退出时,重启,包括被信号终止和超时等
on-abnormal: # 只有被信号终止或超时,才会重启
on-abort: # 只有在收到没有捕捉到的信号终止时,才会重启
on-watchdog: # 超时退出时,才会重启
always: # 不管什么退出原因,都会重启
# 对于守护进程,推荐用on-failure
RestartSec字段:
表示systemd重启服务之前,需要等待的秒数:RestartSec: 30

各种Exec*字段:
ExecStart: # 启动服务时执行的命令
ExecReload: # 重启服务时执行的命令
ExecStop: # 停止服务时执行的命令
ExecStartPre: # 启动服务前执行的命令
ExecStartPost:# 启动服务后执行的命令
ExecStopPost: # 停止服务后执行的命令

连词号(-):在所有启动设置之前,添加的变量字段,都可以加上连词号
表示抑制错误,即发生错误时,不影响其他命令的执行。
比如`EnviromentFile=-/etc/sysconfig/xxx` 表示即使文件不存在,也不会抛异常

WantedBy字段:
multi-user.target: # 表示多用户命令行状态,这个设置很重要
graphical.target: # 表示图形用户状体,它依赖于multi-user.target