Linux systemd 服务全面详解

在这里插入图片描述

一、systemd 是什么?

systemd 是 Linux 系统的现代初始化系统(init)和服务管理器,替代传统的 SysVinit 和 Upstart。它不仅是系统启动的“总指挥”,还统一管理服务、日志、设备挂载、定时任务等。


核心作用

  1. 服务管理:启动、停止、重启服务,设置开机自启。
  2. 并行启动:根据依赖关系并行启动服务,大幅缩短系统启动时间。
  3. 日志管理:通过 journalctl 集中管理所有服务的日志。
  4. 资源控制:限制服务的 CPU、内存等资源使用。
  5. 按需启动:通过套接字或总线激活服务,节省资源。

二、核心概念与配置

1. 单元(Unit)

systemd 通过单元文件(Unit File)管理系统资源,文件扩展名表示类型:

单元类型作用常见示例
.service管理后台服务(如 Nginx、MySQL)nginx.service
.socket管理套接字(按需启动服务)docker.socket
.timer定时任务(替代 crondaily-backup.timer
.target逻辑分组(类似运行级别)multi-user.target
.mount文件系统挂载home.mount

2. 服务文件(.service)详解

服务文件通常位于 /usr/lib/systemd/system/(系统默认)或 /etc/systemd/system/(自定义覆盖)。
一个典型服务文件分为三个部分:

示例:Python Web 应用服务
[Unit]
Description=My Web Application
After=network.target  # 确保网络就绪后启动[Service]
Type=simple
User=www-data
Group=www-data
WorkingDirectory=/opt/myapp  # 指定工作目录(避免路径错误)
ExecStart=/usr/bin/python3 /opt/myapp/app.py
Restart=on-failure
Environment="APP_ENV=production"  # 设置环境变量(如配置生产模式)[Install]
WantedBy=multi-user.target  # 关联到多用户命令行模式
关键参数解析
  • [Unit] 部分

    • Description:服务描述(用于日志和状态显示)。
    • After/Before:定义启动顺序(如 After=network.target)。
    • Requires:强依赖服务(依赖失败则当前服务失败)。
    • Wants:弱依赖服务(依赖失败不影响当前服务)。
  • [Service] 部分

    • Type:服务类型(见下文详解)。
    • ExecStart:启动命令(必须用绝对路径)。
    • Restart:重启策略(noon-failurealways)。
    • User/Group:以指定用户/组运行(提升安全性)。
    • Environment:设置环境变量(如数据库密码)。
  • [Install] 部分

    • WantedBy:定义服务所属的目标(target),控制开机启动场景。

3. 服务类型(Type)详解

类型行为适用场景
simple主进程启动即视为服务已就绪(默认类型)。简单脚本或后台程序。
forking主进程 fork 子进程后退出,systemd 通过 PIDFile 跟踪子进程。传统守护进程(如 Nginx)。
oneshot执行一次性任务后退出,需配合 RemainAfterExit=yes 维持状态。初始化脚本或备份任务。
notify服务通过 sd_notify 发送就绪信号后,systemd 才认为服务启动完成。需要明确初始化完成的服务。
为什么需要 forking 类型?
  • 历史兼容性:传统守护进程(如 Nginx)会自行 fork 子进程并退出父进程。
  • 脱离终端:子进程脱离终端控制,避免被 Ctrl+C 或终端关闭信号终止。
  • 资源消耗:父进程短暂存在后退出,实际资源由子进程占用,与 simple 类型无显著差异。

4. 目标(Target)

target 是 systemd 的逻辑分组单位,定义系统的不同运行状态(类似传统运行级别):

Target 名称作用
multi-user.target多用户命令行模式(无图形界面)。
graphical.target图形界面模式。
rescue.target单用户救援模式(用于系统修复)。
timers.target定时任务关联的目标。

关联服务
[Install] 部分设置 WantedBy=multi-user.target,表示系统进入该目标时服务自动启动。


三、常用命令速查

1. 服务管理

# 启动/停止/重启服务
systemctl start <服务名>
systemctl stop <服务名>
systemctl restart <服务名># 查看服务状态
systemctl status <服务名># 启用/禁用开机自启
systemctl enable <服务名>
systemctl disable <服务名># 重新加载修改后的服务文件
systemctl daemon-reload

2. 日志管理

# 查看服务日志
journalctl -u <服务名># 实时追踪日志
journalctl -fu <服务名># 按时间筛选日志
journalctl --since "09:00" --until "10:00"

3. 系统状态

# 列出所有运行中的服务
systemctl list-units --type=service# 分析系统启动时间
systemd-analyze

四、典型案例与场景

1. 部署 Python Web 应用

需求:将脚本 /opt/myapp/app.py 设为后台服务,开机自启。
步骤

  1. 创建服务文件 /etc/systemd/system/myapp.service
    [Unit]
    Description=My Python Web App
    After=network.target[Service]
    User=www-data
    Group=www-data
    WorkingDirectory=/opt/myapp  # 确保脚本能读取同目录下的文件
    ExecStart=/usr/bin/python3 /opt/myapp/app.py
    Restart=always
    Environment="APP_ENV=production"  # 传递环境变量[Install]
    WantedBy=multi-user.target
    
  2. 启用并启动服务:
    systemctl daemon-reload
    systemctl enable myapp
    systemctl start myapp
    

2. 定时备份文件(替代 cron)

需求:每天凌晨 3 点执行备份脚本 /opt/scripts/backup.sh
步骤

  1. 创建服务文件 /etc/systemd/system/backup.service
    [Unit]
    Description=Daily File Backup[Service]
    Type=oneshot
    ExecStart=/bin/bash /opt/scripts/backup.sh
    
  2. 创建定时器文件 /etc/systemd/system/backup.timer
    [Unit]
    Description=Run backup daily at 3 AM[Timer]
    OnCalendar=*-*-* 03:00:00  # 每日 3 点执行
    Persistent=true            # 如果错过时间,开机后补执行[Install]
    WantedBy=timers.target
    
  3. 启用定时器:
    systemctl enable backup.timer
    systemctl start backup.timer
    

关联逻辑

  • .timer.service 文件必须同名(或通过 Unit= 显式指定)。
  • 定时器触发时,systemd 执行对应的服务。

3. 限制服务资源

需求:限制服务最多使用 512MB 内存和 50% CPU。
服务文件配置

[Service]
...
MemoryMax=512M  # 最大内存限制
CPUQuota=50%    # CPU 时间配额

五、常见问题排查

1. 服务启动失败

  • 查看日志journalctl -u <服务名>
  • 检查路径和权限:确保 ExecStart 的命令路径正确,且 User 有权限访问相关文件。
  • 手动测试命令:直接运行 ExecStart 的命令验证是否报错。

2. 服务无法开机自启

  • 确认服务已启用:运行 systemctl is-enabled <服务名>
  • 检查 [Install] 配置:确保 WantedBy 指向正确的 target(如 multi-user.target)。

3. 环境变量未生效

  • 显式设置变量:在服务文件中使用 Environment="KEY=value"
  • 避免 Shell 变量:systemd 不读取用户 Shell 的环境变量。

六、高级功能

1. 按需启动(Socket Activation)

通过 .socket 单元监听端口,当有请求时启动服务:

# /etc/systemd/system/myservice.socket
[Socket]
ListenStream=8080  # 监听 TCP 端口 8080[Install]
WantedBy=sockets.target

2. 服务依赖与顺序

[Unit]
Requires=postgresql.service  # 强依赖
After=postgresql.service     # 确保 PostgreSQL 先启动

七、总结

systemd 的核心优势

  1. 统一管理:服务、日志、定时任务等通过单一工具管理。
  2. 高效并行:依赖驱动的启动机制大幅优化启动速度。
  3. 灵活配置:通过单元文件实现细粒度控制。

学习建议

  • 从简单服务文件入手,逐步实践定时任务和资源限制。
  • 善用 journalctlsystemctl status 排查问题。
  • 参考官方文档:systemd.io

附:速查表

# 查看服务依赖关系
systemctl list-dependencies <服务名># 杀死服务进程
systemctl kill <服务名># 查看所有定时器
systemctl list-timers

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/76686.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jetson AGX orin--ARM64 换源报错Packages 404 Not Found [IP: 2402:f000:1:400::2 443]

问题 原因&#xff1a; ARM64结构不能使用X86结构的源&#xff0c;清华源不完全支持ARM64。使用下面这个源 sudo vim /etc/apt/sources.list 删掉原来的&#xff0c;改成这个 # ARM64 架构专用源 deb [archarm64] http://ports.ubuntu.com/ubuntu-ports focal main restrict…

ARM 性能分析工具:Streamline

文章目录 1. 前言2. 安装2.1 在 Host 安装 Arm Performance Studio2.2 在 ARM 目标平台安装 gatord 3. 使用3.1 离线方式3.2 在线方式3.3 添加符号表 4. 参考资料 1. 前言 限于作者能力水平&#xff0c;本文可能存在谬误&#xff0c;因此而给读者带来的损失&#xff0c;作者不…

React: hook相当于函数吗?

一、Hook 是一个函数&#xff0c;但不仅仅是函数 函数的本质 Hook 确实是一个 JavaScript 函数&#xff0c;例如 useState、useEffect 或自定义 Hook 都是函数。它们可以接受参数&#xff08;如初始状态值或依赖项数组&#xff09;&#xff0c;并返回结果&#xff08;如状态值和…

Android学习总结之算法篇三(排序)

归并排序原理 归并排序&#xff08;Merge Sort&#xff09;是一种采用分治法&#xff08;Divide and Conquer&#xff09;的排序算法&#xff0c;其基本思想是将一个大问题分解为多个小问题&#xff0c;分别解决这些小问题&#xff0c;然后将小问题的解合并起来得到原问题的解…

Python列表(List)深度解析

列表(List)是Python中最基础且强大的数据结构之一&#xff0c;但它的底层实现和特性远比表面看起来复杂。本文将深入探讨列表的各个方面。 1. 列表基础特性 1.1 可变序列类型 lst [1, 2, 3] lst[1] 20 # 可变性1.2 异构容器 mixed [1, "hello", 3.14, [1, 2]…

Java基础-设计模式详解

摘要&#xff1a;设计模式是软件工程中解决常见问题的经典方案。本文结合Java语言特性&#xff0c;深入解析常用设计模式的核心思想、实现方式及实际应用场景&#xff0c;帮助开发者提升代码质量和可维护性。 一、设计模式概述 1.1 什么是设计模式&#xff1f; 设计模式&…

Docker 构建镜像异常报错解决

报错一&#xff1a; # 启动 SSH Agent eval $(ssh-agent -s)# 添加私钥到 agent (替换为你的实际密钥路径) ssh-add ~/.ssh/id_ed25519# 验证密钥已加载 ssh-add -L# 查看 SSH_AUTH_SOCK 是否设置 echo $SSH_AUTH_SOCK # 应输出类似&#xff1a;/tmp/ssh-XXXXXX/agent.XXXX# 显…

动态规划似包非包系列一>组合总和IIV

目录 题目分析&#xff1a;状态表示&#xff1a;状态转移方程&#xff1a;初始化填表顺序返回值&#xff1a;代码呈现&#xff1a; 题目分析&#xff1a; 状态表示&#xff1a; 状态转移方程&#xff1a; 初始化填表顺序返回值&#xff1a; 代码呈现&#xff1a; class Soluti…

Linux下调试器gdb_cgdb使用

文章目录 一、样例代码二、使用watchset var确定问题原因条件断点 一、样例代码 #include <stdio.h>int Sum(int s, int e) {int result 0;int i;for(i s; i < e; i){result i;}return result; }int main() {int start 1;int end 100;printf("I will begin…

JSON Crack:简化数据可视化的参数编辑器

简介 在当今数据驱动的世界中&#xff0c;JSON&#xff08;JavaScript Object Notation&#xff09;作为一种轻量级的数据交换格式&#xff0c;广泛应用于各种开发和数据分析场景。然而&#xff0c;复杂的JSON数据往往难以阅读和理解&#xff0c;特别是在数据量庞大时&#xf…

PostgreSQL 删除数据库

PostgreSQL 删除数据库 概述 PostgreSQL 是一款功能强大的开源关系型数据库管理系统&#xff0c;它提供了丰富的功能和强大的性能。在数据库管理过程中&#xff0c;有时需要删除不再需要的数据库&#xff0c;以释放资源或进行数据库维护。本文将详细介绍如何在 PostgreSQL 中…

Linux内核物理内存组织结构

一、系统调用sys_mmap 系统调用mmap用来创建内存映射&#xff0c;把创建内存映射主要的工作委托给do_mmap函数&#xff0c;内核源码文件处理&#xff1a;mm/mmap.c 二、系统调用sys_munmap 1、vma find_vma (mm, start); // 根据起始地址找到要删除的第一个虚拟内存区域 vma 2…

Mac强制解锁APP或文件夹

当Mac安装过火绒企业版、云安全访问服务之类的APP需要卸载的时候&#xff0c;会发现需要管理员密码&#xff0c;正常的卸载流程走不下去&#xff0c;直接删除APP&#xff0c;会提示“不能完成此操作&#xff0c;xxx已锁定”的信息&#xff0c;此处就记录一下如何关闭锁定状态&a…

Mixed Content: The page at https://xxx was loaded over HTTPS

一、核心原因分析 Mixed Content 警告是由于 HTTPS 页面中引用了 HTTP 协议的资源(如脚本、图片、iframe 等),导致浏览器因安全策略阻止加载这些非加密内容。HTTP 资源可能被中间人攻击篡改,破坏 HTTPS 页面的整体安全性。 二、推荐解决方案 1. 强制资源升级为 HTTPS •…

ARXML文件解析-1

目录 1 摘要2 ARXML文件2.1 作用及典型应用场景2.2 **ARXML文件的结构树**2.3 TAG&#xff08;XML元素&#xff09;2.4 ARXML文件关键元素解析2.4.1 XML声明与处理指令2.4.2 XML注释2.4.3 ADMIN-DATA元素2.4.3 语言相关元素2.4.5 AR-PACKAGE体系结构2.4.6. 数据转换框架2.4.7 S…

[ISP 3A ] AE的常用算法分析

&#x1f4cc; 自动曝光&#xff08;AE, Auto Exposure&#xff09;解析 自动曝光&#xff08;AE&#xff09;是相机通过调节 曝光参数&#xff08;增益、快门时间、光圈等&#xff09;来确保拍摄出的图像亮度适宜的算法。AE 需要根据环境光线变化自动调整曝光&#xff0c;以避…

大模型学习二:DeepSeek R1+蒸馏模型组本地部署与调用

一、说明 DeepSeek R1蒸馏模型组是基于DeepSeek-R1模型体系&#xff0c;通过知识蒸馏技术优化形成的系列模型&#xff0c;旨在平衡性能与效率。 1、技术路径与核心能力 基础架构与训练方法‌ ‌DeepSeek-R1-Zero‌&#xff1a;通过强化学习&#xff08;RL&#xff09;训练&…

STM32入门学习笔记(持续更新)

b站江协科技资料 通过网盘分享的文件&#xff1a;STM32入门教程资料 链接: https://pan.baidu.com/s/1-rOi83sUK8CqUNsHQuvxew?pwd8krh 提取码: 8krh LED灯闪烁0402 #include "stm32f10x.h" // Device header #include "Delay.h"int m…

企业安全——FIPs

0x00 前言 先来看一道题目。这道题目涉及到的就是道德规范和互联网相关内容&#xff0c;本文会对相关内容进行描述和整理。 正确答案是&#xff1a;D 注意FIPs的主要目的是为了限制&#xff0c;也就是针对数据的守则。 0x01 RFC 1087 1989年1月 互联网架构委员会 IAB 发布了…

【Linux系统编程】进程概念,进程状态

目录 一&#xff0c;操作系统&#xff08;Operator System&#xff09; 1-1概念 1-2设计操作系统的目的 1-3核心功能 1-4系统调用和库函数概念 二&#xff0c;进程&#xff08;Process&#xff09; 2-1进程概念与基本操作 2-2task_struct结构体内容 2-3查看进程 2-4通…