天天看点

【运维】将二进制文件应用添加到服务通过systemctl管理

一、系统

                    linux环境: Centos 7

 二、配置文件:

          1、进入service文件目录:

                /usr/lib/systemd/system

          2、service文件解析

          示例:sshd.service文件

[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.service
Wants=sshd-keygen.service

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

[Install]
WantedBy=multi-user.target      

            解析:

这个文件由三个部分组成:Unit\Service\Install

 

[Unit]主要是为了解决依赖关系。常见的添加Requires、After,如果这个依赖是可选的,那么是Wants、After。依赖关系通常被用在服务(service)而不是(target)上,所以上述的httpd所依赖的仅仅是一些target,因而也就没有Requires和Wants出现。

[service]可选择几种不同的服务启动方式,启动方式通过Type参数进行设置。

Type=simple(默认值):systemd认为该服务将立即启动。服务进程不会fork。如果该服务要启动其他服务,不要使用此类型启动,除非该服务是socket激活型。

Type=forking:systemd认为当该服务进程fork,且父进程退出后服务启动成功。对于常规的守护进程(daemon),除非你确定此启动方式无法满足需求,使用此类型启动即可。使用此启动类型应同时指定 PIDFile=,以便systemd能够跟踪服务的主进程。

Type=oneshot:这一选项适用于只执行一项任务、随后立即退出的服务。可能需要同时设置 RemainAfterExit=yes 使得 systemd 在服务进程退出之后仍然认为服务处于激活状态。

Type=notify:与 Type=simple 相同,但约定服务会在就绪后向 systemd 发送一个信号。这一通知的实现由 libsystemd-daemon.so 提供。

Type=dbus:若以此方式启动,当指定的 BusName 出现在DBus系统总线上时,systemd认为服务就绪。

 

修改现存单元文件

要更改由软件包提供的单元文件,先创建名为 /etc/systemd/system/<单元名>.d/ 的目录(如/etc/systemd/system/httpd.service.d/),然后放入 *.conf文件,其中可以添加或重置参数。这里设置的参数优先级高于原来的单元文件。

例如,如果想添加一个额外的依赖,创建这么一个文件即可:

/etc/systemd/system/<unit>.d/customdependency.conf[Unit]Requires=<新依赖>After=<新依赖>

然后运行以下命令使更改生效:

systemctl daemon-reload

 
在services模块添加以下配置可使服务异常挂掉后自动重启
#################### 服务异常重启  #########################
StartLimitIntervalSec=0
Restart=always
RestartSec=1
###########################################################



 


可以使用jourlctl来进行systemd相关启动日志的查看。

journalctl -b -0  # 显示本次启动的信息

journalctl -b -1  # 显示上次启动的信息


可以通过systemctl status **.service 查看运行状态

       

  三、示例:

            本人想将auditbeat二进制工具通过systemctl服务管理

[Unit]
Description=Security Auditbeat Service
DefaultDependencies=no

[Service]
Type=simple
PIDFile=/run/auditbeat.pid
ExecStartPre=/usr/bin/rm -f /run/auditbeat.pid
ExecStart= /root/go/GOPATH/src/github.com/elastic/beats/auditbeat/auditbeat -e -c /root/go/GOPATH/src/github.com/elastic/beats/auditbeat/auditbeat.yml

[Install]
WantedBy=multi-user.target