Centos7 自定义systemctl服务脚本
概述
systemctl
是一个控制systemd服务的命令行工具,systemd是运行于Linux系统中替换sysvinit和upstart的一个服务管理器。systemctl可以添加、删除、启动、停止、重启和获取系统服务的状态等。 它是管理和启动系统服务的首选工具。
在/usr/lib/systemd/system目录下包含了各种unit文件,有service后缀的服务unit,有target后缀的开机级别unit等,这里介绍关于service后缀的文件。因为systemd在开机要想执行自启动,都是通过这些*.service 的unit控制的,服务又分为系统服务(system)和用户服务(user)。
- 系统服务:开机不登陆就能运行的程序(常用于开机自启)。
- 用户服务:需要登陆以后才能运行的程序
本篇文章用于总结下,具体的使用方式。
配置
Centos7的服务systemctl
脚本一般存放在:/usr/lib/systemd , 目录下又有user和system之分
1/usr/lib/systemd/system # 系统服务,开机不需要登录就能运行的程序(相当于开机自启)
2/usr/lib/systemd/user # 用户服务,需要登录后才能运行的程序
目录下又存在两种类型的文件:
1*.service # 服务unit文件
2*.target # 开机级别unit
CentOS7的每一个服务以.service结尾,一般会分为3部分:[Unit]、[Service]和[Install]
1vim /usr/lib/systemd/system/xxx.service
2[Unit] # 主要是服务说明
3Description=test # 简单描述服务
4After=network.target # 描述服务类别,表示本服务需要在network服务启动后在启动
5Before=xxx.service # 表示需要在某些服务启动之前启动,After和Before字段只涉及启动顺序,不涉及依赖关系。
6
7[Service] # 核心区域
8Type=forking # 表示后台运行模式。
9User=user # 设置服务运行的用户
10Group=user # 设置服务运行的用户组
11KillMode=control-group # 定义systemd如何停止服务
12PIDFile=/usr/local/test/test.pid # 存放PID的绝对路径
13Restart=no # 定义服务进程退出后,systemd的重启方式,默认是不重启
14ExecStart=/usr/local/test/bin/startup.sh # 服务启动命令,命令需要绝对路径
15PrivateTmp=true # 表示给服务分配独立的临时空间
16
17[Install]
18WantedBy=multi-user.target # 多用户
字段说明
1Type的类型有:
2 simple(默认):# 以ExecStart字段启动的进程为主进程
3 forking: # ExecStart字段以fork()方式启动,此时父进程将退出,子进程将成为主进程(后台运行)。一般都设置为forking
4 oneshot: # 类似于simple,但只执行一次,systemd会等它执行完,才启动其他服务
5 dbus: # 类似于simple, 但会等待D-Bus信号后启动
6 notify: # 类似于simple, 启动结束后会发出通知信号,然后systemd再启动其他服务
7 idle: # 类似于simple,但是要等到其他任务都执行完,才会启动该服务。
8
9EnvironmentFile:
10 指定配置文件,和连词号组合使用,可以避免配置文件不存在的异常。
11
12Environment:
13 后面接多个不同的shell变量。
14 例如:
15 Environment=DATA_DIR=/data/elk
16 Environment=LOG_DIR=/var/log/elasticsearch
17 Environment=PID_DIR=/var/run/elasticsearch
18 EnvironmentFile=-/etc/sysconfig/elasticsearch
19
20连词号(-):在所有启动设置之前,添加的变量字段,都可以加上连词号
21 表示抑制错误,即发生错误时,不影响其他命令的执行。
22 比如`EnviromentFile=-/etc/sysconfig/xxx` 表示即使文件不存在,也不会抛异常
23
24KillMode的类型:
25 control-group(默认):# 当前控制组里的所有子进程,都会被杀掉
26 process: # 只杀主进程
27 mixed: # 主进程将收到SIGTERM信号,子进程收到SIGKILL信号
28 none: # 没有进程会被杀掉,只是执行服务的stop命令
29Restart的类型:
30 no(默认值): # 退出后无操作
31 on-success: # 只有正常退出时(退出状态码为0),才会重启
32 on-failure: # 非正常退出时,重启,包括被信号终止和超时等
33 on-abnormal: # 只有被信号终止或超时,才会重启
34 on-abort: # 只有在收到没有捕捉到的信号终止时,才会重启
35 on-watchdog: # 超时退出时,才会重启
36 always: # 不管什么退出原因,都会重启
37 # 对于守护进程,推荐用on-failure
38RestartSec字段:
39 表示systemd重启服务之前,需要等待的秒数:RestartSec: 30
40
41各种Exec*字段:
42 # Exec* 后面接的命令,仅接受“指令 参数 参数..”格式,不能接受<>|&等特殊字符,很多bash语法也不支持。如果想支持bash语法,需要设置Tyep=oneshot
43 ExecStart: # 启动服务时执行的命令
44 ExecReload: # 重启服务时执行的命令
45 ExecStop: # 停止服务时执行的命令
46 ExecStartPre: # 启动服务前执行的命令
47 ExecStartPost:# 启动服务后执行的命令
48 ExecStopPost: # 停止服务后执行的命令
49
50
51WantedBy字段:
52 multi-user.target: # 表示多用户命令行状态,这个设置很重要
53 graphical.target: # 表示图形用户状体,它依赖于multi-user.target
systemctl 命令
1systemctl daemon-reload # 重载系统服务
2systemctl enable *.service # 设置某服务开机启动
3systemctl start *.service # 启动某服务
4systemctl stop *.service # 停止某服务
5systemctl reload *.service # 重启某服务
发布日期:2023-10-08 20:07 字数:246 用时
标签云
alpine(1) api网关(1) async(1) await(1) centos(4) cli(1) client-go(1) debug(1) docker(10) docker-compose(1) dockerfile(1) embed(1) es6(1) etcd(1) etcdctl(1) freemesh(2) git(6) go(5) go-zeus(5) goland(2) golang(7) grafana(2) grpc(5) grpcurl(1) homebrew(1) homedir(1) http(2) hugo(1) java(2) javascript(3) job(1) js(1) json(1) k8s(16) k8s部署指南(1) kubebuilder(1) kubectl(4) kubernetes(1) linux(2) localecompare(1) lombok(1) metrics(2) mock(1) mysql(1) npm(1) nsenter(1) nvm(1) pnpm(2) pprof(1) prettier(1) prometheus(2) protobuf3(1) protoc(1) qiankun(1) request(1) scss(1) servicemesh(1) spring(1) springcloud->freemesh(1) ssh(2) systemctl(1) tcpdump(1) typescript(2) vite(2) vscode(2) vue(8) vue-admin(2) vue3(1) webssh(1) xtermjs(1) xxl-job(1) yarn(1) zookeeper(1) 云原生(4) 云原生框架(1) 介绍(1) 单体架构->freemesh(1) 单元化(1) 博客(1) 压缩(1) 可观测(1) 后台管理系统(1) 命名规范(1) 多云多活(1) 如水网(1) 安全(1) 安装(1) 容器(2) 开发联调神器(1) 微前端(1) 微服务(2) 微服务架构->freemesh(1) 微服务框架(1) 快速开始(1) 控制面(1) 数据面(1) 文集(2) 服务发现(1) 服务网格(1) 流量泳道(1) 流量管理(1) 监控告警(1) 端口映射(1) 证书(1) 负载均衡(1) 配置(1)