前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >编写一个服务systemd的启动方式

编写一个服务systemd的启动方式

作者头像
dgds
发布2023-08-02 18:05:39
3640
发布2023-08-02 18:05:39
举报
文章被收录于专栏:dgds的运维dgds的运维

工作中遇到了一个问题,开发人员编写了一个程序,想要开机自启动,一开始还想偷点懒直接把启动命令直接写到rc.local,后来发现毛病太多,索性直接编写一个systemd文件来控制启动

代码语言:txt
复制
[Unit]
Description=consistent server daemon           #相当于介绍
After=network.target auditd.service            #这个就是你这个服务所依赖的服务,就是你这个服务启动前有哪些服务是必须有的


[Service]
ExecStart=/usr/bin/python3 /home/work/eagle/consistent.py   #这就是我服务的启动命令
ExecReload=/bin/kill -HUP $MAINPID
KillMode=control-group                #杀掉你这个服务的所有子进程,你不加这个那子进程还在会导致你服务重启失败
Restart=always                        #除非systemctl stop 否则就重启服务,这个是因为我这个程序有时会因为网络、io阻塞导致服务一直等待,所以配合下面的选项,一小时重启服务一次
RuntimeMaxSec=1h                      #允许服务运行1小时,超过一小时直接杀掉
RestartSec=5                                #这就是个时间,重启间隔
EnvironmentFile=-/etc/environment       #引用变量,带给启动的程序,他会先读取你设置的这个文件,把变量拿到,在提供给应用,所以变量文件要是更改的话你得重启服务

[Install]
WantedBy=multi-user.target            #开机自启,这个就是最重要的

这是我最终写出来的文件,但ststemd选项不止于此,于是写篇文章给列出来方便以后使用

接下来以这个为例,标记一下这个模块该怎么使用

代码语言:txt
复制
[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.service
Wants=sshd-keygen.service

[Service]
EnvironmentFile=/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd -D $OPTIONS
ExecReload=/bin/kill -HUP $MAINPID
Type=simple
KillMode=process
Restart=on-failure
RestartSec=42s

[Install]
WantedBy=multi-user.target

Unit 区块:启动顺序与依赖关系。

Unit区块的Description字段给出当前服务的简单描述,Documentation字段给出文档位置。

接下来的设置是启动顺序和依赖关系,这个比较重要。

After字段:表示如果network.target或sshd-keygen.service需要启动,那么sshd.service应该在它们之后启动。

相应地,还有一个Before字段,定义sshd.service应该在哪些服务之前启动。

注意,After和Before字段只涉及启动顺序,不涉及依赖关系。

举例来说,某 Web 应用需要 postgresql 数据库储存数据。在配置文件中,它只定义要在 postgresql 之后启动,而没有定义依赖 postgresql 。上线后,由于某种原因,postgresql 需要重新启动,在停止服务期间,该 Web 应用就会无法建立数据库连接。

设置依赖关系,需要使用Wants字段和Requires字段。

Wants字段:表示sshd.service与sshd-keygen.service之间存在"弱依赖"关系,即如果"sshd-keygen.service"启动失败或停止运行,不影响sshd.service继续执行。

Requires字段则表示"强依赖"关系,即如果该服务启动失败或异常退出,那么sshd.service也必须退出。

注意,Wants字段与Requires字段只涉及依赖关系,与启动顺序无关,默认情况下是同时启动的。

Service 区块:启动行为

启动命令

许多软件都有自己的环境参数文件,该文件可以用EnvironmentFile字段读取。

EnvironmentFile字段:指定当前服务的环境参数文件。该文件内部的key=value键值对,可以用$key的形式,在当前配置文件中获取。

上面的例子中,sshd 的环境参数文件是/etc/sysconfig/sshd。

配置文件里面最重要的字段是ExecStart。

ExecStart字段:定义启动进程时执行的命令。

上面的例子中,启动sshd,执行的命令是/usr/sbin/sshd -D O P T I O N S , 其 中 的 变 量 OPTIONS,其中的变量OPTIONS,其中的变量OPTIONS就来自EnvironmentFile字段指定的环境参数文件。

与之作用相似的,还有如下这些字段。

ExecReload字段:重启服务时执行的命令

ExecStop字段:停止服务时执行的命令

ExecStartPre字段:启动服务之前执行的命令

ExecStartPost字段:启动服务之后执行的命令

ExecStopPost字段:停止服务之后执行的命令

启动类型

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

simple(默认值):ExecStart字段启动的进程为主进程

forking:ExecStart字段将以fork()方式启动,此时父进程将会退出,子进程将成为主进程

oneshot:类似于simple,但只执行一次,Systemd 会等它执行完,才启动其他服务

dbus:类似于simple,但会等待 D-Bus 信号后启动

notify:类似于simple,启动结束后会发出通知信号,然后 Systemd 再启动其他服务

idle:类似于simple,但是要等到其他任务都执行完,才会启动该服务。一种使用场合是为让该服务的输出,不与其他服务的输出相混合

重启行为

Service区块有一些字段,定义了重启行为。

KillMode字段:定义 Systemd 如何停止 sshd 服务。

上面这个例子中,将KillMode设为process,表示只停止主进程,不停止任何sshd 子进程,即子进程打开的 SSH session 仍然保持连接。这个设置不太常见,但对 sshd 很重要,否则你停止服务的时候,会连自己打开的 SSH session 一起杀掉。

KillMode字段可以设置的值如下。

control-group(默认值):当前控制组里面的所有子进程,都会被杀掉

process:只杀主进程

mixed:主进程将收到 SIGTERM 信号,子进程收到 SIGKILL 信号

none:没有进程会被杀掉,只是执行服务的 stop 命令。

接下来是Restart字段。

Restart字段:定义了 sshd 退出后,Systemd 的重启方式。

上面的例子中,Restart设为on-failure,表示任何意外的失败,就将重启sshd。如果 sshd 正常停止(比如执行systemctl stop命令),它就不会重启。

Restart字段可以设置的值如下。

no(默认值):退出后不会重启

on-success:只有正常退出时(退出状态码为0),才会重启

on-failure:非正常退出时(退出状态码非0),包括被信号终止和超时,才会重启

on-abnormal:只有被信号终止和超时,才会重启

on-abort:只有在收到没有捕捉到的信号终止时,才会重启

on-watchdog:超时退出,才会重启

always:不管是什么退出原因,总是重启

对于守护进程,推荐设为on-failure。对于那些允许发生错误退出的服务,可以设为on-abnormal。

最后是RestartSec字段。

RestartSec字段:表示 Systemd 重启服务之前,需要等待的秒数。上面的例子设为等待42秒。

Install 区块

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

WantedBy字段:表示该服务所在的 Target。

Target的含义是服务组,表示一组服务。WantedBy=multi-user.target指的是,sshd 所在的 Target 是multi-user.target。

这个设置非常重要,因为执行systemctl enable sshd.service命令时,sshd.service的一个符号链接,就会放在/etc/systemd/system目录下面的multi-user.target.wants子目录之中。

修改配置文件后重启

一般配置文件放到/usr/lib/systemd/system/xxx.service

但有的debian系统没有/usr/lib/systemd/system这个文件,可以把文件放到/lib/systemd/system目录下

代码语言:txt
复制
systemctl daemon-reload
更新一下
就可以使用systemctl stop/start/restart 来管理服务了

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Unit 区块:启动顺序与依赖关系。
  • Service 区块:启动行为
    • 启动命令
      • 启动类型
        • 重启行为
        • Install 区块
        • 修改配置文件后重启
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档