`

编写systemd下服务脚本

 
阅读更多
输出激活的单元:
$ systemctl
以下命令等效:
$ systemctl list-units
输出运行失败的单元:
$ systemctl --failed
所有可用的单元文件存放在 /usr/lib/systemd/system/ 和 /etc/systemd/system/ 目录(后者优先级更高)。查看所有已安装服务:
$ systemctl list-unit-files
立即激活单元:
# systemctl start <单元>
立即停止单元:
# systemctl stop <单元>
重启单元:
# systemctl restart <单元>
重新加载配置:
# systemctl reload <单元>
输出单元运行状态:
$ systemctl status <单元>
检查单元是否配置为自动启动:
$ systemctl is-enabled <单元>
开机自动激活单元:
# systemctl enable <单元>
取消开机自动激活单元:
# systemctl disable <单元>
显示单元的手册页(必须由单元文件提供):
# systemctl help <单元>
重新载入 systemd,扫描新的或有变动的单元:
# systemctl daemon-reload




http://blog.csdn.net/fu_wayne/article/details/38018825
编写systemd下服务脚本
Red Hat Enterprise Linux 7(RHEL 7)已经将服务管理工具从SysVinit和Upstart迁移到了systemd上,相应的服务脚本也需要改变。前面的版本里,所有的启动脚本都是放在/etc/rc.d/init.d/ 目录下。这些脚本都是bash脚本,可以让系统管理员控制这些服务的状态,通常,这些脚本中包含了start,stop,restart这些方法,以提供系统自动调用这些方法。但是在RHEL 7中当中已经完全摒弃了这种方法,而采用了一种叫unit的配置文件来管理服务。

■Systemd下的unit文件
Unit文件专门用于systemd下控制资源,这些资源包括服务(service)、套接字(socket)、设备(device)、挂载点(mount point)、自动挂载点(automount point)、交换文件或分区(a swap file or partition)…
所有的unit文件都应该配置[Unit]或者[Install]段.由于通用的信息在[Unit]和[Install]中描述,每一个unit应该有一个指定类型段,例如[Service]来对应后台服务类型unit.
unit 类型如下:
service :守护进程的启动、停止、重启和重载是此类 unit 中最为明显的几个类型。
socket :此类 unit 封装系统和互联网中的一个socket。当下,systemd支持流式, 数据报和连续包的AF\_INET,AF\_INET6,AF\_UNIXsocket 。也支持传统的 FIFOs 传输模式。每一个 socket unit 都有一个相应的服务 unit 。相应的服务在第一个“连接”进入 socket 或 FIFO 时就会启动(例如:nscd.socket 在有新连接后便启动 nscd.service)。
device :此类 unit 封装一个存在于 Linux设备树中的设备。每一个使用 udev 规则标记的设备都将会在 systemd 中作为一个设备 unit 出现。udev 的属性设置可以作为配置设备 unit 依赖关系的配置源。
mount :此类 unit 封装系统结构层次中的一个挂载点。
automount :此类 unit 封装系统结构层次中的一个自挂载点。每一个自挂载 unit 对应一个已挂载的挂载 unit (需要在自挂载目录可以存取的情况下尽早挂载)。
target :此类 unit 为其他 unit 进行逻辑分组。它们本身实际上并不做什么,只是引用其他 unit 而已。这样便可以对 unit 做一个统一的控制。(例如:multi-user.target 相当于在传统使用 SysV 的系统中运行级别5);bluetooth.target 只有在蓝牙适配器可用的情况下才调用与蓝牙相关的服务,如:bluetooth 守护进程、obex 守护进程等)
snapshot :与 targetunit 相似,快照本身不做什么,唯一的目的就是引用其他 unit 。

■认识service的unit文件
扩展名:.service
路径:
     /etc/systemd/system/*     ――――  供系统管理员和用户使用
      /run/systemd/system/*     ――――  运行时配置文件
      /usr/lib/systemd/system/*   ――――  安装程序使用(如RPM包安装)

以下是一段service unit文件的例子,属于/usr/lib/systemd/system/NetworkManager.service文件,它描述的是系统中的网络管理服务。
[Unit]
Description=Network Manager
Wants=network.target
Before=network.target network.service
                                                                                                                                                                               
[Service]
Type=dbus
BusName=org.freedesktop.NetworkManager
ExecStart=/usr/sbin/NetworkManager --no-daemon
# NM doesn't want systemd to kill its children for it
KillMode=process
 
[Install]
WantedBy=multi-user.target
Alias=dbus-org.freedesktop.NetworkManager.service
Also=NetworkManager-dispatcher.service



整个文件分三个部分,[Unit]·[Service]·[Install]
[Unit]:记录unit文件的通用信息。
[Service]:记录Service的信息
[Install]:安装信息。

Unit主要包含以下内容:
●  Description:对本service的描述。
●  Before, After:定义启动顺序,Before=xxx.service,代表本服务在xxx.service启动之前启动。After=xxx.service,代表本服务在xxx之后启动。
●  Requires: 这个单元启动了,那么它“需要”的单元也会被启动; 它“需要”的单元被停止了,它自己也活不了。但是请注意,这个设定并不能控制某单元与它“需要”的单元的启动顺序(启动顺序是另外控制的),即 Systemd 不是先启动 Requires 再启动本单元,而是在本单元被激活时,并行启动两者。于是会产生争分夺秒的问题,如果 Requires 先启动成功,那么皆大欢喜; 如果 Requires 启动得慢,那本单元就会失败(Systemd 没有自动重试)。所以为了系统的健壮性,不建议使用这个标记,而建议使用 Wants 标记。可以使用多个 Requires。
●  RequiresOverridable:跟 Requires 很像。但是如果这条服务是由用户手动启动的,那么 RequiresOverridable 后面的服务即使启动不成功也不报错。跟 Requires 比增加了一定容错性,但是你要确定你的服务是有等待功能的。另外,如果不由用户手动启动而是随系统开机启动,那么依然会有 Requires 面临的问题。
●  Requisite:强势版本的 Requires。要是这里需要的服务启动不成功,那本单元文件不管能不能检测等不能等待都立刻就会失败。
●  Wants:推荐使用。本单元启动了,它“想要”的单元也会被启动。但是启动不成功,对本单元没有影响。
●  Conflicts:一个单元的启动会停止与它“冲突”的单元,反之亦然。

Service主要包含以下内容:
●  Type:service的种类,包含下列几种类型:
            ----simple 默认,这是最简单的服务类型。意思就是说启动的程序就是主体程序,这个程序要是退出那么一切都退出。
           -----forking 标准 Unix Daemon 使用的启动方式。启动程序后会调用 fork() 函数,把必要的通信频道都设置好之后父进程退出,留下守护精灵的子进程
           -----oneshot种服务类型就是启动,完成,没进程了。
notify,idle类型比较少见,不介绍。
●  ExecStart:服务启动时执行的命令,通常此命令就是服务的主体。
        ------如果你服务的类型不是 oneshot,那么它只可以接受一个命令,参数不限。
       ------多个命令用分号隔开,多行用 \ 跨行。
●  ExecStartPre, ExecStartPost:ExecStart执行前后所调用的命令。
●  ExecStop:定义停止服务时所执行的命令,定义服务退出前所做的处理。如果没有指定,使用systemctl stop xxx命令时,服务将立即被终结而不做处理。
●  Restart:定义服务何种情况下重启(启动失败,启动超时,进程被终结)。可选选项:no, on-success, on-failure,on-watchdog, on-abort
●  SuccessExitStatus:参考ExecStart中返回值,定义何种情况算是启动成功。
    eg:SuccessExitStatus=1 2 8 SIGKILL
Install主要包含以下内容:
●  WantedBy:何种情况下,服务被启用。
    eg:WantedBy=multi-user.target(多用户环境下启用)
●  Alias:别名

■旧的命令与systemd命令的映射
service systemctl Description
service name start    ---->  systemctl start name.service   ●Starts a service.
service name stop   ---->  systemctl stopname.service   ●Stops a service.
service name restart  ---->  systemctl restartname.service  ●Restarts a service.
service name condrestart ---->
systemctl try-restart name.service ●Restarts a service only if it is running.
service name reload  ---->  systemctl reloadname.serviceReloads configuration.
service name status ---->  systemctl status name.service
systemctl is-active name.service
●Checks if a service isrunning.
service --status-all  ----> systemctl list-units –type service --all
●Displays the status of all services.chkconfig systemctl
chkconfig name on  ---->   systemctl enablename.service ●Enables a service.
chkconfig name off   ---->   systemctl disablename.service ●Disables a service.
chkconfig --list name  ---->  systemctl statusname.service
system ctl is-enabled name.service
●Checks if a service is enabled.
chkconfig --list  ----> systemctl list-unit-files –type service
●Lists all services and checks if they are enabled.



■创建自己的systemd服务
弄清了unit文件的各项意义,我们可以尝试编写自己的服务,与以前用SysV来编写服务相比,整个过程比较简单。unit文件有着简洁的特点,是以前臃肿的脚本所不能比的。
在本例中,尝试写一个命名为my-demo.service的服务,整个服务很简单:在开机的时候将服务启动时的时间写到一个文件当中。可以通过这个小小的例子来说明整个服务的创建过程。
Step1:编写属于自己的unit文件,命令为my-demo.service,整个文件如下:
[Unit]
Description=My-demo Service
                                                                                                                                      
[Service]
Type=oneshot
ExecStart=/bin/bash /root/test.sh
StandardOutput=syslog
StandardError=inherit
 
[Install]
WantedBy=multi-user.target


Step2:将上述的文件拷贝到RHEL 7系统中/usr/lib/systemd/system/*目录下
Step3:编写unit文件中ExecStart=/bin/bash /root/test.sh所定义的test.sh文件,将其放在定义的目录当中,此文件是服务的执行主体。文件内容如下:
#!/bin/bash
                                                                                                                                      
date >> /tmp/date
Step4:将my-demo.service注册到系统当中执行命令:
# systemctl enable my-demo.service
输出:ln -s'/usr/lib/systemd/system/my-demo.service' '/etc/systemd/system/multi-user.target.wants/my-demo.service'
输出表明,注册的过程实际上就是将服务链接到/etc/systemd/system/目录下。

至此服务已经创建完成。重新启动系统,会发现/tmp/date文件已经生成,服务在开机时启动成功。当然本例当中的test.sh文件可以换成任意的可执行文件作为服务的主体,这样就可以实现各种各样的功能。
分享到:
评论

相关推荐

    Python-用Python写一个systemd服务的教程

    Python作为一种强大的脚本语言,也可以用来编写systemd服务。这篇教程将深入探讨如何使用Python创建systemd服务,帮助你更好地理解和应用这一技术。 首先,了解systemd的基本概念是非常必要的。systemd主要由单元...

    arm64架构 Docker 离线安装包、systemd脚本

    总结来说,"arm64架构 Docker 离线安装包、systemd脚本"涉及了在基于arm64架构的操作系统上,特别是银河麒麟V10SP1,如何离线安装和配置Docker,以及利用systemd管理Docker服务的过程。这对于那些需要在FT2000+或...

    python-systemd-tutorial:用Python编写systemd服务的教程

    事实证明,用Python编写systemd服务很容易,但是systemd的复杂性一开始可能令人生畏。 本教程旨在帮助您入门。 当您感到迷路或需要详细的细节时,请转至,该非常详尽。 但是,文档分布在多个页面上,要查找所需的...

    Node.js-小命令行工具能够简便向systemd添加服务

    在这个场景下,Node.js被用来创建一个命令行工具,这个工具可以帮助系统管理员更方便地将自定义的服务脚本或应用程序注册为systemd服务单元,从而在系统启动时自动启动这些服务。 描述中的“小命令行工具能够简便向...

    ubuntu-wsl2-systemd-script:用于在当前Ubuntu WSL2映像上启用systemd支持的脚本

    通过运行这个脚本,用户能够启用systemd,以便在该环境下运行那些依赖systemd启动和管理的服务。 **标签解析:** 1. **windows** - 表明这是与Windows操作系统相关的技术。 2. **bash** - 指的是Bash Shell,是...

    linux常用的服务脚本大全.zip

    在Linux操作系统中,服务脚本是...掌握服务脚本的编写和使用是Linux系统管理员的基本技能,它能帮助我们更高效地管理Linux服务器,确保服务的稳定运行。学习和理解这些脚本的运作方式对于提升Linux运维能力至关重要。

    hive systemctl启停hiveserver2和metastore服务.pdf

    总结一下,本文介绍了如何通过编写Shell脚本和创建systemd服务单元文件来实现Hive的Metastore和HiveServer2服务的一键启停。这种方法简化了操作,提高了管理Hive服务的便利性,尤其适合需要频繁启停服务的场景。在...

    Python-导出systemd日志到一个外部服务如cloudwatchelasticsearch

    Systemd日志存储在`/var/log/journal/`目录下,采用journalctl命令进行查询和管理。journalctl支持丰富的查询选项,如时间范围、服务名、级别等,方便对日志进行筛选。 接下来,我们将探讨如何通过Python与systemd...

    一个简单的Bash脚本示例,该脚本用于检查Nginx服务的状态,并根据服务状态执行相应的操作(如启动、停止或重启Nginx)

    通过编写这样的脚本,可以显著简化Nginx服务的日常维护工作,减少人工干预的需求,并确保服务的稳定性和可用性。此外,该脚本还具有一定的灵活性,能够适应不同类型的Linux发行版和服务管理系统。

    PyPI 官网下载 | systemd-0.8.9.tar.gz

    从压缩包子文件的文件名称"systemd-0.8.9"来看,解压后应该会包含该库的源代码文件、文档、测试文件以及可能的安装脚本等。通常,这样的源代码包会有setup.py文件,它是Python项目的一个标准入口,用于构建、安装和...

    linux学习-将seafile启动脚本设置为开机启动服务.docx

    ### Linux学习:将Seafile启动脚本设置为开机启动...此外,通过编写Systemd服务文件来管理应用和服务,不仅简化了系统维护工作,还提升了系统的整体安全性。希望本文能帮助您更好地理解和掌握Linux下的服务管理技巧。

    DM8_Linux服务脚本使用手册.pdf

    这些脚本是使用Shell语言编写的,可以执行诸如启动数据库实例、关闭正在运行的实例、检查服务状态等任务。 **1.2 服务数量管理** 在DM8中,可能有多个数据库服务实例同时运行,每个实例对应不同的数据库实例ID。...

    nginx主主集群(自动启动服务脚本)

    4. 系统集成:将服务脚本和Systemd配置文件放入适当目录,使用Systemd管理Nginx服务。 【知识点四】:Nginx主主集群实践 1. 安装Nginx:在所有节点上安装相同版本的Nginx。 2. 配置文件:配置Nginx,包括监听端口...

    如何编写linux服务.zip

    编写Linux服务通常涉及到创建脚本、配置启动机制以及管理服务的生命周期。以下是对"如何编写Linux服务"这一主题的详细说明: 1. **Linux Shell脚本**: Linux服务通常由Shell脚本(bash、sh等)编写,这些脚本包含...

    批量重启动unix、linux系统服务的脚本

    批量重启动服务的脚本通常会使用shell脚本语言编写,如bash。下面是一个基本的bash脚本示例,用于批量重启动服务: ```bash #!/bin/bash # 定义服务列表 services=("service1" "service2" "service3") # 遍历服务...

    srvstatus:SystemD服务状态

    该python3脚本的主要目标是检查给定SystemD服务的列表并将其状态发送到InfluxDB数据库,以便可以将它们用于Grafana仪表板。 该脚本是用python编写的,我试图尽可能多地使用标准库,但是您仍然需要运行pip install...

    lua-systemd:Lua的系统绑定

    - **服务单元文件编写**:lua-systemd允许使用Lua编写systemd服务单元文件,利用Lua的灵活性和表达力,使得服务配置更直观易懂。 - **API接口**:提供了一系列Lua API,如`start()`, `stop()`, `status()`等,用于...

    shell脚本发布jar包服务,war包服务

    - 在Linux系统中,可以使用`systemd`服务单元文件来定义一个服务,包括启动命令、工作目录、依赖项等。 6. **部署流程**: - 创建一个Java应用后,将其打包成JAR或WAR。 - 编写shell脚本以控制应用程序的生命...

    脚本撰写指南.pdf

    在进行Shell脚本编写时,还需注意一些特定的文件系统位置,如log4j.properties和search.yml配置文件应该放在/etc/search/目录下,而searchx.service文件应该放在/etc/systemd/system/目录下。执行dpkg安装elastic...

Global site tag (gtag.js) - Google Analytics