也想出现在这里? 联系我们

在Linux系统中创建和修改systemd单元文件

作者 : 小编 本文共6090个字,预计阅读时间需要16分钟 发布时间: 2022-11-3 共4.81K人阅读
也想出现在这里? 联系我们

(1)单元文件概述

单元文件包含单元的指令和行为信息。在后台systemctl命令和单元文件一起工作。为了出色而正确的完成工作,系统管理员必须能够手工编辑单元文件。一般系统管理员手工创建的单元文件建议存放在/etc/systemd/system/目录下面。单元配置文件的格式是:

复制代码

代码如下:

unit_name.type_extension

这里的unit_name代表单元名称,type_extension代表单元类型。单元文件可以作为附加的文件放置到一个目录下面,比如为了定制sshd.service服务,可以创建sshd.service.d/custom.conf文件,在文件中做一些自定义的配置。同样的,可以创建sshd.service.wants/和sshd.service.requires/目录。这些目录包含sshd服务关联服务的软连接,在系统安装的时候,这些软连接或自动创建,也可以手工创建软连接。许多单元配置文件可以使用单元说明符–通配的字符串,可以在单元文件被引导的时候动态的被变量替换。这使创建一些通用的单元配置模版成为可能。

(2)理解单元文件结构

典型的单元文件包含三节:[Unit]节,包含不依赖单元类型的一般选项,这些选型提供单元描述,知道单元行为,配置单元和其他单元的依赖性。[unittype]节,如果单元有特定的类型指令,在unittype节这些指令被组织在一起。举个例子,服务单元文件包含[Service]节,里面有经常使用的服务配置。[Install]节,包含systemctlenable或者disable的命令安装信息。1)[Unit]节选项Description单元描述信息,这些文字信息在systemclstatus命令是会输出。Documentation单元文档信息的URLs。After定义在那些单元之后启动,本单元只在制定的单元启动之后启动,不像Requires选项,After选项不明确激活特定的单元,Before选项则是有相反的功能。Requires配置单元的依赖性,在Requires选项中的单元需要一起被激活,如果有一个单元启动失败,其他单元都不会被启动。Wants比Requires选项依赖性要弱很多,如果列表之中的的单元启动失败,不会对其他单元造成影响,这是推荐的建立自定义单元依赖性的方式。Conflicts定义单元冲突关系,和Requires相反。2)[unittype]类型是[Service]时的选项Type配置单元进程在启动时候的类型,影响执行和关联选项的功能,可选的关键字是:simple默认值,进程和服务的主进程一起启动;forking进程作为服务主进程的一个子进程启动,父进程在完全启动之后退出。oneshot同simple相似,但是进程在启动单元之后随之退出。dbus同simple相似,但是随着单元启动后只有主进程得到D-BUS名字。notify同simple相似,但是随着单元启动之后,一个主要信息被sd_notify()函数送出。idle同simple相似,实际执行进程的二进制程序会被延缓直到所有的单元的任务完成,主要是避免服务状态和shell混合输出。ExecStart指定启动单元的命令或者脚本,ExecStartPre和ExecStartPost节指定在ExecStart之前或者之后用户自定义执行的脚本。Type=oneshot允许指定多个希望顺序执行的用户自定义命令。ExecStop指定单元停止时执行的命令或者脚本。ExecReload指定单元重新加载是执行的命令或者脚本。Restart这个选项如果被允许,服务重启的时候进程会退出,会通过systemctl命令执行清除并重启的操作。RemainAfterExit如果设置这个选择为真,服务会被认为是在激活状态,即使所以的进程已经退出,默认的值为假,这个选项只有在Type=oneshot时需要被配置。3)[Install]节选项Alias为单元提供一个空间分离的附加名字。RequiredBy单元被允许运行需要的一系列依赖单元,RequiredBy列表从Require获得依赖信息。WantBy单元被允许运行需要的弱依赖性单元,Wantby从Want列表获得依赖信息。Also指出和单元一起安装或者被协助的单元。DefaultInstance实例单元的限制,这个选项指定如果单元被允许运行默认的实例。4)一个postfix服务的例子:单元文件位于/usr/lib/systemd/system/postifix.service,内容如下:

复制代码

代码如下:

[Unit]Description=PostfixMailTransportAgentAfter=syslog.targetnetwork.targetConflicts=sendmail.serviceexim.service[Service]Type=forkingPIDFile=/var/spool/postfix/pid/master.pidEnvironmentFile=-/etc/sysconfig/networkExecStartPre=-/usr/libexec/postfix/aliasesdbExecStartPre=-/usr/libexec/postfix/chroot-updateExecStart=/usr/sbin/postfixstartExecReload=/usr/sbin/postfixreloadExecStop=/usr/sbin/postfixstop[Install]WantedBy=multi-user.target

(3)创建自定义的单元文件

以下几种场景需要自定义单元文件:希望自己创建守护进程;为现有的服务创建第二个实例;引入SysV init脚本。另外一方面,有时候需要修改已有的单元文件。下面介绍创建单元文件的步骤:1)准备自定义服务的执行文件。可执行文件可以是脚本,也可以是软件提供者的的程序,如果需要,为自定义服务的主进程准备一个PID文件,一保证PID保持不变。另外还可能需要的配置环境变量的脚本,确保所以脚本都有可执行属性并且不需要交互。2)在/etc/systemd/system/目录创建单元文件,并且保证只能被root用户编辑:

复制代码

代码如下:

touch/etc/systemd/system/name.servicechmod664/etc/systemd/system/name.service

文件不需要执行权限。3)打开name.service文件,添加服务配置,各种变量如何配置视所添加的服务类型而定,下面是一个依赖网络服务的配置例子:

复制代码

代码如下:

[Unit]Description=service_descriptionAfter=network.target[Service]ExecStart=path_to_executableType=forkingPIDFile=path_to_pidfile[Install]WantedBy=default.target

4)通知systemd有个新服务添加:

复制代码

代码如下:

systemctldaemon-reloadsystemctlstartname.service

(4)创建emacs.service例子:

1)创建文件,并确保正确权限:

复制代码

代码如下:

~]#touch/etc/systemd/system/emacs.service~]#chmod664/etc/systemd/system/emacs.service

2)添加配置信息:

复制代码

代码如下:

[Unit]Description=Emacs:theextensible,self-documentingtexteditor[Service]Type=forkingExecStart=/usr/bin/emacs–daemonExecStop=/usr/bin/emacsclient–eval\”(kill-emacs)\”Environment=SSH_AUTH_SOCK=%t/keyring/sshRestart=always[Install]WantedBy=default.target

3)通知systemd并开启服务:

复制代码

代码如下:

~]#systemctldaemon-reload~]#systemctlstartemacs.service

(5)创建第二个sshd服务的例子

1)拷贝sshd_config文件

复制代码

代码如下:

]#cp/etc/ssh/sshd{,-second}_config

2)编辑sshd-second_config文件,添加22220的端口,和PID文件:

复制代码

代码如下:

Port22220PidFile/var/run/sshd-second.pid

如果还需要修改其他参数,请阅读帮助。3)拷贝单元文件:

复制代码

代码如下:

~]#cp/usr/lib/systemd/system/sshd{,-second}.service

4)编辑单元文件sshd-second.service修改描述字段

复制代码

代码如下:

Description=OpenSSHserversecondinstancedaemon

添加sshd.service服务在After关键字之后:

复制代码

代码如下:

After=syslog.targetnetwork.targetauditd.servicesshd.service

移除sshdkey创建:

复制代码

代码如下:

ExecStartPre=/usr/sbin/sshd-keygen

移除这一行在执行脚本里,添加第二sshd服务的配置文件:

复制代码

代码如下:

ExecStart=/usr/sbin/sshd-D-f/etc/ssh/sshd-second_config$OPTIONS

修改后的sshd-second.service文件内容如下:

复制代码

代码如下:

[Unit]Description=OpenSSHserversecondinstancedaemonAfter=syslog.target network.targe tauditd.service sshd.service[Service]EnvironmentFile=/etc/sysconfig/sshdExecStart=/usr/sbin/sshd -D -f /etc/ssh/sshd-second_config$OPTIONSExecReload=/bin/kill -HUP $MAINPIDKillMode=processRestart=on-failureRestartSec=42s[Install]WantedBy=multi-user.target

5)如果使用SELinux,添加tcp端口,负责第二sshd服务的端口就会被拒绝绑定:

复制代码

代码如下:

~]#semanage port -a -tssh_port_t -p tcp22220

6)设置开机启动并测试:

复制代码

代码如下:

~]#systemctl enable sshd-second.service~]$ssh -p 22220 user@server

确保防火墙端口也开放。

(6)修改已经存在的单元文件

systemd单元配置文件默认保存在/usr/lib/systemd/system/目录,系统管理员不建议直接修改这个目录下的文件,自定义的文件在/etc/systemd/system/目录下,如果有扩展的需求,可以使用以下方案:创建一个目录/etc/systemd/system/unit.d/,这个是最推荐的一种方式,可以参考初始的单元文件,通过附件配置文件来扩展默认的配置,对默认单元文件的升级会被自动升级和应用。从/usr/lib/systemd/system/拷贝一份原始配置文件到/etc/systemd/system/,然后修改。复制的版本会覆盖原始配置,这种方式不能增加附件的配置包,用于不需要附加功能的场景。如果需要恢复到默认的配置文件,只需要删除/etc/systemd/system/下的配置文件就可以了,不需要重启机器,使用如下命令应用改变就可以:

复制代码

代码如下:

systemctl daemon-reload

daemon-reload选项重新加载所以单元文件并重新创建依赖书,在需要立即应用单元文件改变的时候使用。另外,也可以使用下面的命令达到同样的目的:

复制代码

代码如下:

init q

还有,如果修改的是一个正在运行服务的单元文件,服务需要被重启下:

复制代码

代码如下:

systemct lrestart name.service

(7)扩展默认单元配置文件配置

为了扩展默认的单元文件配置,需要先在/etc/systemd/system/下创建一个目录,用root执行类似下面的命令:

复制代码

代码如下:

mkdir/etc/systemd/system/name.service.d

在刚才创建的目录之下创建配置文件,必须以.conf文件结尾。例如创建一个自定义的依赖文件,内容如下:

复制代码

代码如下:

[Unit]Requires=new_dependencyAfter=new_dependency

另外一个例子,可以配置重启的时候,在主进程退出后30秒在重启,配置例子如下:

复制代码

代码如下:

[Service]Restart=alwaysRestartSec=30

推荐每次只产生一个小文件,每个文件只聚焦完善一个功能,这样配置文件很容易被移除或者链接到其他服务对的配置目录中。为了应用刚才的修改,使用root执行以下操作:

复制代码

代码如下:

systemctldaemon-reloadsystemctlrestartname.service

例子:扩展httpd.service服务配置为了是httpd服务启动的时候执行用户自定义的脚本,需要修改httpd的单元配置文件,执行以下几步操作,首先创建一个自定义文件的目录及自定义文件:

复制代码

代码如下:

~]#mkdir/etc/systemd/system/httpd.service.d~]#touch/etc/systemd/system/httpd.service.d/custom_script.conf

假设自定义文件位置在/usr/local/bin/custom.sh,将这个信息添加到custom_script.conf自定义脚本中:

复制代码

代码如下:

[Service]ExecStartPost=/usr/local/bin/custom.sh

应用更改:

复制代码

代码如下:

~]#systemctldaemon-reload~]#systemctlrestarthttpd.service

1. 本站所提供的源码模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: rayer@88.com),我们会及时删除,给您带来的不便,我们深表歉意!
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » 在Linux系统中创建和修改systemd单元文件

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
织梦模板使用说明
你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html

发表评论

Copyright 2015-2020 版权所有 资源分享吧 Rights Reserved. 蜀ICP备14022927号-1
开通VIP 享更多特权,建议使用QQ登录