Linux systemd服务
Linux systemd服务
systemctl命令
systemctl是systemd的主命令,用于管理系统和服务。以下是一些常用的systemctl命令:
- 查看服务状态:systemctl status 服务名
- 启动服务:systemctl start 服务名
- 停止服务:systemctl stop 服务名
- 重启服务:systemctl restart 服务名
- 设置开机自启动:systemctl enable 服务名
- 设置开机不启动:systemctl disable 服务名
- 重新加载配置文件:systemctl daemon-reload
systemd的Unit文件
systemd通过unit文件来管理服务,unit文件统一了过去各种不同系统资源配置格式。unit文件通常包含三个区块:Unit、Service和Install。
Unit区块
Unit区块主要用于服务说明,包括服务的简单描述、服务类别、启动顺序等。例如:
[Unit]
Description=test
After=network.target
以下是一些常见的Unit区块参数:
- Description:一段简短的描述性文字,用于说明这个Unit的功能或作用。这是Unit区块中最常见也最重要的参数之一。
- Documentation:指定服务的文档位置,可以是一个或多个文档的URL路径。这个参数不是必需的,但如果有相关的文档,可以在这里提供,以便管理员或其他用户快速查找。
- Requires:表示当前Unit依赖的其他Unit列表。如果这些依赖的Unit没有运行,那么当前Unit会启动失败(注意:这一行为可能因systemd版本或配置而异,有些情况下依赖服务启动失败,当前服务也可能继续启动)。但是,如果依赖的Unit在启动后停止运行,当前Unit也会被停止。
- Wants:与Requires相似,但区别在于如果列出的Unit启动失败,当前Unit不会启动失败。Wants表示的是一种“弱依赖”关系,即这些Unit的启动对当前Unit的启动不是必需的,但如果它们能启动,对当前Unit是有益的。
- BindsTo:与Requires非常相似,但表示的是一种更强的关联。如果BindsTo列出的任何一个Unit停止运行,当前Unit也会停止运行。这是一种“绑定”关系,表示当前Unit与列出的Unit紧密相关,它们的生命周期是同步的。
- After:表示当前Unit应该在哪些Unit之后启动。这个参数不会阻塞当前Unit的启动,但会确保在After列出的Unit启动完成后,再启动当前Unit。
- Before:与After相反,表示当前Unit应该在哪些Unit之前启动。但是,Before并不会阻塞这些Unit的启动,只是设定了一个启动顺序的优先级。
- Conflicts:表示与当前Unit有冲突的Unit列表。如果Conflicts列出的任何一个Unit已经在运行,那么会尝试停止这个已运行的冲突Unit,并启动当前Unit。这是一种互斥关系,确保在同一时间内,冲突的Unit不会同时运行。
- Condition... 和 Assert...:这两类参数用于定义当前Unit运行必须满足的条件。Condition参数在条件不满足时,Unit会简单地停止启动;而Assert参数在条件不满足时,会报告启动失败。这些条件可以是系统状态、环境变量等。
- PartOf:这个参数指定了一个或多个Unit,表示当前Unit是这些Unit的一部分。当PartOf列出的任何一个Unit停止或重启时,当前Unit也会停止或重启。这是一种“从属”关系。
需要注意的是,以上参数并不是必须全部使用的,而是根据具体的Unit需求和系统配置来选择合适的参数进行配置。
Service区块
Service区块是unit文件的核心区域,用于定义服务的启动、停止、重启等行为。例如:
[Service]
Type=forking
User=USER
Group=USER
WorkingDirectory=/PATH
ExecStart=/start.sh
Restart=no
以下是一些常见的Service区块参数:
- Type:定义服务启动时的进程行为。
- simple(默认值):直接执行ExecStart指定的命令,启动主进程。
- forking:以fork方式从父进程创建子进程,创建后父进程会立即退出,子进程成为主进程。
- oneshot:类似于simple,但只执行一次,systemd会等它执行完,再继续执行其他服务。
- dbus:等待D-Bus信号后启动。
- notify:类似于simple,但约定服务会在就绪后向systemd发送一个信号。
- idle:类似于simple,但要等到其他任务都执行完,才会启动该服务。
- ExecStart:定义启动服务时要运行的命令和参数。可以是一个完整的命令行,也可以是一个指向脚本的路径。
- ExecStartPre、ExecStartPost:分别定义在ExecStart之前和之后要执行的命令。这些命令可以在服务主进程启动之前或之后执行一些准备工作或清理工作。
- ExecReload:定义重启服务时要执行的命令。这通常用于在不停止服务的情况下重新加载配置或刷新状态。
- ExecStop:定义停止服务时要执行的命令。这通常用于执行清理操作或优雅地关闭服务。
- ExecStopPost:定义在ExecStop之后要执行的命令。这些命令可以在服务完全停止后执行一些清理或后续操作。
- Restart:定义服务退出后是否重新启动,以及如何重新启动。
- no(默认值):不重新启动。
- always:总是重新启动。
- on-success:仅当服务成功退出时重新启动。
- on-failure:仅当服务异常退出时重新启动。
- on-abnormal:仅当服务因信号退出时重新启动。
- on-abort:仅当服务因核心转储退出时重新启动。
- on-watchdog:仅当watchdog超时退出时重新启动。
- RestartSec:定义在重新启动服务之前等待的秒数。这有助于避免在短时间内频繁地启动和停止服务,从而减轻系统负担。
- User 和 Group:指定运行服务的用户和组。这有助于增强服务的安全性,确保它们以适当的权限运行。
- WorkingDirectory:定义服务启动时的工作目录。这可以确保服务在正确的上下文中运行,并访问其所需的文件和资源。
- Environment:设置服务运行时的环境变量。这可以包括配置选项、路径或其他必要的设置。
- TimeoutStartSec、TimeoutStopSec:分别定义启动和停止服务时允许的最长时间。如果服务在指定的时间内没有启动或停止,systemd将采取相应的措施(如终止服务)。
- EnvironmentFile:指定一个包含服务所需的环境变量定义的文件。当服务启动时,systemd会读取这个文件,并将其中定义的环境变量加载到服务的运行环境中。使用EnvironmentFile的好处是可以将环境变量的定义集中管理,方便修改和查看。
- PrivateTmp:布尔值,当设置为true时,为每个服务进程分配独立的临时文件目录,提高安全性。
- ProtectSystem、ProtectHome:这些参数用于增强服务的安全性,通过限制服务对系统或其他用户主目录的访问来实现。
需要注意的是,以上参数并不是必须全部使用的,而是根据具体的Unit需求和系统配置来选择合适的参数进行配置。
Install区块
Install区块用于定义服务的安装信息,如服务所属的target和是否开机自启动。例如:
[Install]
WantedBy=multi-user.target
以下是一些常见的Install区块参数:
- WantedBy:这是最常用的参数之一,用于指定一个或多个target,当这些target被激活时,该服务也会被激活(即开机自启)。例如,WantedBy=multi-user.target表示该服务在达到多用户运行级别时被激活。
- RequiredBy:与WantedBy类似,但表示更强烈的依赖关系。如果RequiredBy指定的target被激活,那么该服务必须被激活。不过,在systemd的实践中,WantedBy更为常见,而RequiredBy的使用相对较少。
- Alias:为服务提供一个或多个别名。通过别名,也可以使用systemctl命令来管理服务,而不仅仅是使用服务的原始名称。
- Also:指定当前服务激活时,同时也会被激活的其他服务。这可以用于设置服务之间的连锁启动关系。
- DefaultInstance:当服务是模板化的(即使用%i作为实例名称的占位符)时,此参数用于指定默认的实例名称。然而,并非所有服务都会使用模板化实例,因此这个参数并不常用。
需要注意的是,以上参数并不是必须全部使用的,而是根据具体的Unit需求和系统配置来选择合适的参数进行配置。
示例
创建一个systemd服务文件,通常放在/etc/systemd/system/目录下。例如,创建名为your-service.service的文件。
在这个文件中,定义你的服务,包括一个ExecStart指令来指定开机时要执行的命令或脚本。
vim /etc/systemd/system/prometheus.service
[Unit]
Description=Prometheus Service
After=network.target
[Service]
Type=simple
ExecStart=/opt/performance/prometheus-3.0.0-beta.0.linux-amd64/prometheus --config.file=/opt/performance/prometheus-3.0.0-beta.0.linux-amd64/prometheus.yml --storage.tsdb.retention.time=30d
Restart=always
[Install]
WantedBy=multi-user.target
重新加载配置
sudo systemctl daemon-reload
启动你的服务以测试它是否按预期工作:
sudo systemctl start prometheus.service
查看服务状态
systemctl status prometheus.service
设置开机时自动启动:
sudo systemctl enable prometheus.service
Linux systemd服务的更多相关文章
- Linux之systemd服务配置及自动重启
layout: post title: Linux之systemd服务配置及自动重启 date: 2019-09-09 tags: linux --- Linux之systemd服务配置及自动重启 0 ...
- CentOS 7下设置Docker代理(Linux下Systemd服务的环境变量配置)
Docker守护程序使用HTTP_PROXY,HTTPS_PROXY以及NO_PROXY环境变量在其启动环境来配置HTTP或HTTPS代理的行为.无法使用daemon.json文件配置这些环境变量. ...
- systemd服务详解-技术流ken
简介 在centos5中生成和管理用户空间中的进程以及完成系统的初始化使用的是init,并且是依次启动.在centos6中则是使用的upstart,在一定程度上实现了并行启动,但是仍然存在依赖关系,到 ...
- centos7下将java -jar命令运行一个项目做成systemd服务
有些时候运行一个java项目在linux下通过一条简单的java命令即可,如: #nohup java -jar jenkins.war & ###这里为后台运行jenkins 在此背景下,j ...
- Linux systemd资源控制初探
Linux systemd资源控制初探 本文记录一次cgroup子目录丢失问题,并简单探索了Linux systemd的资源控制机制. 问题现象 我们希望通过systemd拉起服务并通过cgroup限 ...
- linux systemd 从简单的例子入门
linux systemd 从简单的例子入门 网上很多相关链接,一上来就给一大堆命令和讲解,让人头都大. 我们希望有一个service(服务),让它在开机启动的时候就执行. 用 root 登陆以后: ...
- [转帖]Linux systemd 常用命令
Linux systemd 常用命令 https://www.cnblogs.com/tsdxdx/p/7288490.html systemctl hostnamectl timedatectl l ...
- [转帖][Linux]systemd和sysV
[Linux]systemd和sysV 转自:https://www.cnblogs.com/EasonJim/p/7168216.html 在Debian8中systemd和sysVinit同时 ...
- linux的服务管理(centos6和Centos7)和网络管理(网卡配置),计划服务cron
服务和网络 管理 init ifcfg ens33 1.服务: Linux系统中提供的功能,统称为服务,如:at服务.cron服务.web服务.FTP服务.sshd服务等. 服务是由已经在运行的进程 ...
- Linux文件共享服务之NFS
NFS(Network File System) 网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中,本地NFS的客户端应用可 ...
随机推荐
- npm报错error:0308010C:digital envelope routines::unsupported
error:0308010C:digital envelope routines::unsupported 出现这个错误是因为 node.js V17版本中最近发布的OpenSSL3.0, 而Open ...
- C++学习笔记-Cherno C++系列
21-23.[Cherno C++]C++中的静态(static) static变量只在编译单元内部链接 静态变量的作用域只在单个文件内 建议:在非特殊情况下,永远使用static定义全局变量以限制作 ...
- 设置 crossdomain.xml 文件实施 HTTP 流式传输
本文概括介绍了跨域策略文件,以及如何在 Adobe Media Server 中为 HTTP 流式传输配置该文件. 为什么需要采用 crossdomain.xml 文件? 跨域策略文件 跨域策略文件是 ...
- vant中dialog的使用
按照文档上的方式引入组件,但是还是会报错说没有注册 引入方式如下: import { Cell, CellGroup, Field, Dialog } from 'vant'; components: ...
- Vue 二维码组件
1.前言 该组件依赖qrcode.js与element-ui 支持二维码大小配置,点击大图预览 该组件以vue文件形式进行封装,需要配置httpVueLoader插件进行引入,其他格式请自行更改源码 ...
- 下列哪个选项是对ICMP FLOOD攻击的正确描述?
A. 通过重复发送HTTP GET请求,将内容传输的负载施加到攻击目标服务器上. B. 通过使用ping命令发送大量请求包,导致通向被攻击服务器过载并阻止访问. C. 通过发送与连接启动请求对应 ...
- Three.js案例-360全景房看
在 360° 看房功能中,我们需要在浏览器中创建一个类似虚拟现实的场景,使得用户能够查看环境的每一个角落.这一功能的实现本质上是利用 球体映射技术,即通过将全景图作为纹理贴图映射到一个反向的球体上,用 ...
- 云消息队列备份 | CKafka、TDMQ 消息队列数据备份到 COS
前言 随着业务规模的不断扩大,企业越来越重视构建高性能.高可用的大型分布式系统.为了解决应用耦合,合理进行流量削锋,腾讯云提供了包括 CKafka 和 TDMQ 在内的一系列消息队列中间件.为了更方便 ...
- 【杂谈】服务端能同时处理多少个 Socket 连接?背后的资源与限制分析
一个服务端进程能同时连接多少个 Socket? 要理解一个服务端进程能同时支持多少个连接,首先我们需要明确一个 socket 连接 的表示方式.一个连接由四个部分组成:[LocalIP:LocalPo ...
- ASP.NET Core 中的 Request Feature
ASP.NET Core 中的 Request Feature https://docs.microsoft.com/en-us/aspnet/core/fundamentals/request-fe ...