Skip to content

Latest commit

 

History

History
122 lines (80 loc) · 5.13 KB

.service文件简介.md

File metadata and controls

122 lines (80 loc) · 5.13 KB

inux 之.service文件简介 (新版systemctl服务)

1. 什么是.service文件?

css复制代码Linux中.service文件是某项服务对应的配置文件,可用于systemd管理和控制的服务的设置。

.service 文件通常包含3个模块,
    即[Unit]控制单元,表示启动顺序和依赖关系;
    [Service]服务,表示服务的定义;
    [Install]安装,表示如何安装配置文件。

2. 文件存放位置

sql复制代码.service 文件配置的服务常用systemd管理。然而,systemd有系统和用户区分;
系统(/user/lib/systemd/system/)、
用户(/etc/lib/systemd/user/)。
一般系统管理员手工创建的单元文件建议存放在/etc/systemd/system/目录下面。

3. 创建.service 文件

复制代码以httpd.service 为例
ini复制代码[Unit]     				
Description=httpd	    #当前配置文件的描述信息
After=network.target        #表示当前服务是在那个服务后面启动,一般定义为网络服务启动后启动

[Service]				
Type=forking			                        #定义启动类型
ExecStart=/usr/local/apache/bin/apachectl start 	#定义启动进程时执行的命令。
ExecReload=/usr/local/apache/bin/apachectl restart      #重启服务时执行的命令
ExecStop=/usr/local/apache/bin/apachectl stop		#定义关闭进程时执行的命令。
PrivateTmp=true						#是否分配独立空间

[Install]
WantedBy=multi-user.target    #表示多用户命令行状态

4. .service 文件 字段介绍

4.1 [Unit] ——主要给出服务描述、启动顺序和依赖关系

ini复制代码Description:当前服务的简单描述。\

Documentation:服务文档\

After和Before:表示启动顺序,不涉及依赖关系。Before=xxx.service表示本服务在xxx.service 启动之前启动,
After=yyy.service表示本服务在yyy.service 之后启动。\

Wants:表示该服务和某服务存在某种弱依赖关系,即某服务停止运行或退出不影响该服务继续运行。\

Requires:表示”强依赖”关系,即某服务停止运行或退出,改服务也必须停止运行。\

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

4.2 [Service]——服务的启动行为以及如何启动、重启、停止等信息

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

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

Type=oneshot:这一选项适用于只执行一项任务、随后立即退出的服务。
可能需要同时设置 RemainAfterExit=yes 使得 systemd 在服务进程退出之后仍然认为服务处于激活状态。
Type=oneshot允许指定多个希望顺序执行的用户自定义命令。\

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

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

Type=idle: systemd会等待所有任务(Jobs)处理完成后,才开始执行idle类型的单元。
除此之外,其他行为和Type=simple 类似。\

PIDFile:pid文件路径

ExecStart:指定启动单元的命令或者脚本,
ExecStartPre和ExecStartPost节指定在ExecStart之前或者之后用户自定义执行的脚本。

ExecReload:指定单元重启时执行的命令或者脚本。

ExecStop:指定单元停止时执行的命令或者脚本。

PrivateTmp:True表示给服务分配独立的临时空间

Restart:这个选项如果被允许,服务重启的时候进程会退出,会通过systemctl命令执行清除并重启的操作。

RemainAfterExit:如果设置这个选择为真,服务会被认为是在激活状态,即使所以的进程已经退出,
默认的值为假,这个选项只有在Type=oneshot时需要被配置。

User:字段可以设置服务的用户名

WorkingDirectory:字段指定服务的安装目录

4.3 [Install]字段介绍——何安装这个配置文件,即怎样做到开机自启

ini复制代码Alias:为单元提供一个空间分离的附加名字。\

RequiredBy:单元被允许运行需要的一系列依赖单元,RequiredBy列表从Require获得依赖信息。\

Also:指出和单元一起安装或者被协助的单元。\

DefaultInstance:实例单元的限制,这个选项指定如果单元被允许运行默认的实例。\

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

Target的含义是服务组,表示一组服务。\

WantedBy=multi-user.target指的是服务所在的Target是multi-user.target
Systemd 有默认的启动 Target就是multi-user.target,在这个组里的所有服务,都将开机启动。