当前位置: 首页 > ds >正文

Python 实现日志备份守护进程

在这里插入图片描述

实训背景

假设你是一名运维工程师,需要为公司的监控系统开发一个简单的日志备份守护进程。该进程需满足以下需求:

  • 后台运行:脱离终端,长期监控指定目录(如 /var/log/app/)中的日志文件。
  • 自动备份:每隔 5 分钟将新增的日志文件压缩备份到 /backup/logs/ 目录。
  • 日志记录:记录守护进程自身的操作日志到 /var/log/backup_daemon.log。
  • 系统服务化:通过 systemd 管理进程的启动、停止和状态查看。

环境准备

  • 操作系统:Ubuntu/CentOS 等主流 Linux 发行版
  • Python 版本:Python 3.x
  • 依赖安装
    # 确保已安装 Python3 和 pip
    sudo apt install python3 python3-pip   # Ubuntu
    sudo yum install python3 python3-pip   # CentOS
    

实训步骤

任务1:编写 Python 守护进程代码

目标:用 Python 实现日志监控与备份逻辑,无需手动处理 fork()

  1. 创建脚本 backup_daemon.py
    import os
    import time
    import logging
    from datetime import datetime
    import subprocess# 配置日志
    logging.basicConfig(filename='/var/log/backup_daemon.log',level=logging.INFO,format='%(asctime)s - %(message)s',datefmt='%Y-%m-%d %H:%M:%S'
    )def backup_logs():log_dir = '/var/log/app'backup_dir = '/backup/logs'# 遍历日志目录for root, _, files in os.walk(log_dir):for file in files:src_path = os.path.join(root, file)dest_path = os.path.join(backup_dir, f"{file}.tar.gz")# 检查是否已备份if not os.path.exists(dest_path):logging.info(f"Backing up {file}...")# 使用 tar 压缩try:subprocess.run(['tar', '-czf', dest_path, src_path],check=True,stdout=subprocess.DEVNULL,stderr=subprocess.DEVNULL)except subprocess.CalledProcessError as e:logging.error(f"Failed to backup {file}: {e}")if __name__ == "__main__":logging.info("Daemon started.")while True:backup_logs()time.sleep(300)  # 5分钟执行一次
    

任务2:配置 systemd 服务

目标:让 Python 脚本以服务形式在后台运行,无需代码内守护进程逻辑。

  1. 创建服务文件

    sudo vim /etc/systemd/system/backup_daemon.service
    
  2. 编写服务配置

    [Unit]
    Description=Python Log Backup Daemon
    After=network.target[Service]
    Type=simple
    ExecStart=/usr/bin/python3 /path/to/backup_daemon.py  # 修改为实际脚本路径
    Restart=on-failure
    RestartSec=5s
    User=root
    WorkingDirectory=/  # 可选:设置工作目录[Install]
    WantedBy=multi-user.target
    
  3. 部署并启动服务

    sudo systemctl daemon-reload
    sudo systemctl start backup_daemon
    sudo systemctl enable backup_daemon
    

任务3:测试与验证

  1. 生成测试日志文件

    sudo touch /var/log/app/test.log
    
  2. 查看备份结果

    ls /backup/logs  # 5分钟后应生成 test.log.tar.gz
    
  3. 查看守护进程日志

    tail -f /var/log/backup_daemon.log
    

任务4:管理服务

  • 查看状态

    systemctl status backup_daemon
    
  • 停止服务

    sudo systemctl stop backup_daemon
    
  • 查看 systemd 日志

    journalctl -u backup_daemon -f  # 实时跟踪日志
    

实训总结

通过本案例,您将掌握:

  1. 使用 Python 实现守护进程逻辑(无需手动 fork())。
  2. 通过 systemd 管理 Python 脚本的后台运行。
  3. 利用 Python 的 logging 模块记录操作日志。

知识要点

  • Python 优势
    • 无需处理底层 fork()setsid(),代码更简洁。
    • 使用 subprocess 模块可轻松调用系统命令(如 tar)。
  • systemd 管理
    • 通过 Type=simple 直接运行前台程序,systemd 自动守护化。
    • 日志可通过 journalctl 统一查看。
  • 日志记录
    • Python 内置 logging 模块提供灵活的日志管理。

扩展优化建议

  1. 增量备份:记录已备份的文件名或时间戳,避免重复压缩。
  2. 异常处理:增加 try/except 捕获文件操作异常。
  3. 配置文件:使用 configparser 模块管理路径、间隔时间等参数。

http://www.xdnf.cn/news/45.html

相关文章:

  • MCP理解笔记及deepseek使用MCP案例介绍
  • 每日算法-链表(23.合并k个升序链表、25.k个一组翻转链表)
  • Java 开发玩转 MCP:从 Claude 自动化到 Spring AI Alibaba 生态整合
  • pycharm无法识别到本地python的conda环境解决方法
  • 【远程管理绿联NAS】家庭云存储无公网IP解决方案:绿联NAS安装内网穿透
  • 数字孪生城市技术应用典型实践案例汇编(22个典型案例)(附下载)
  • 20.3 使用技巧3
  • Openfein实现远程调用的方法(实操)
  • 【音视频开发】第五章 FFmpeg基础
  • 最新Spring Security实战教程(十一)CSRF攻防实战 - 从原理到防护的最佳实践
  • 逻辑回归 (Logistic Regression)
  • 山东大学软件学院创新项目实训开发日志(18)之对话自动生成标题设为用户第一次对话发的文字
  • 第五章 SQLite数据库:3、SQLite 常用语法及使用案例
  • requestAnimationFrame 深度理解
  • AI在多Agent协同领域的核心概念、技术方法、应用场景及挑战 的详细解析
  • 【OSCP-vulnhub】GoldenEye
  • 【秣厉科技】LabVIEW工具包——OpenCV 教程(20):拾遗 - imgproc 基础操作(下)
  • Linux 防火墙( iptables )
  • 大数据调度组件
  • 10.(vue3.x+vite)div实现tooltip功能(css实现)
  • 华为仓颉编程语言深度解析
  • InfiniBand与RoCEv2负载均衡机制的技术梳理与优化实践
  • 服务(service)管理
  • 探寻Gson解析遇到不存在键值时引发的Kotlin的空指针异常的原因
  • 2025第十七届“华中杯”大学生数学建模挑战赛题目B 题 校园共享单车的调度与维护问题完整思路 模型 代码 结果分享
  • 从零开始 保姆级教程 Ubuntu20.04系统安装MySQL8、服务器配置MySQL主从复制、本地navicat远程连接服务器数据库
  • HTML:表格数据展示区
  • 《理解 Java 泛型中的通配符:extends 与 super 的使用场景》
  • 趣味编程之分布式系统:负载均衡的“雨露均沾“艺术
  • Python数据可视化