Python实现日志备份守护进程的示例

 更新时间:2025年04月18日 09:23:16   作者:漫谈网络  
本文主要介绍了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()

创建脚本 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 脚本以服务形式在后台运行,无需代码内守护进程逻辑。

创建服务文件

sudo vim /etc/systemd/system/backup_daemon.service

编写服务配置

[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

部署并启动服务

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

任务3:测试与验证

生成测试日志文件

sudo touch /var/log/app/test.log

查看备份结果

ls /backup/logs  # 5分钟后应生成 test.log.tar.gz

查看守护进程日志

tail -f /var/log/backup_daemon.log

任务4:管理服务

查看状态

systemctl status backup_daemon

停止服务

sudo systemctl stop backup_daemon

查看 systemd 日志

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

实训总结

通过本案例,您将掌握:

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

知识要点

Python 优势:

  • 无需处理底层 fork() 和 setsid(),代码更简洁。
  • 使用 subprocess 模块可轻松调用系统命令(如 tar)。

systemd 管理:

  • 通过 Type=simple 直接运行前台程序,systemd 自动守护化。
  • 日志可通过 journalctl 统一查看。

日志记录:

  • Python 内置 logging 模块提供灵活的日志管理。

扩展优化建议

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

到此这篇关于Python实现日志备份守护进程的示例的文章就介绍到这了,更多相关Python 日志备份守护进程内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • pyecharts结合flask框架的使用

    pyecharts结合flask框架的使用

    这篇文章主要介绍了pyecharts结合flask框架,主要是介绍如何在Flask框架中使用pyecharts,本文通过示例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • Python中serial库的介绍及用法示例

    Python中serial库的介绍及用法示例

    Python的serial库是一个用于串口通信的Python扩展库,它提供了许多方法和功能,用于控制和配置串行端口以及读取和写入串行数据,这篇文章主要给大家介绍了关于Python中serial库用法的相关资料,需要的朋友可以参考下
    2024-07-07
  • 举例介绍Python中的25个隐藏特性

    举例介绍Python中的25个隐藏特性

    这篇文章主要介绍了一些Python中的隐藏特性,从stackoverflow的人气问题回答中整理而来,主要以代码实际解释说明,需要的朋友可以参考下
    2015-03-03
  • Python模块学习 datetime介绍

    Python模块学习 datetime介绍

    Python提供了多个内置模块用于操作日期时间,像calendar,time,datetime。time模块我在之前的文章已经有所介绍,它提供的接口与C标准库time.h基本一致
    2012-08-08
  • python类方法和静态方法详解

    python类方法和静态方法详解

    这篇文章主要为大家介绍了python类方法和静态方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • python pandas中DataFrame类型数据操作函数的方法

    python pandas中DataFrame类型数据操作函数的方法

    下面小编就为大家分享一篇python pandas中DataFrame类型数据操作函数的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-04-04
  • Python jieba结巴分词原理及用法解析

    Python jieba结巴分词原理及用法解析

    这篇文章主要介绍了Python jieba结巴分词原理及用法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • Python实现的简单发送邮件脚本分享

    Python实现的简单发送邮件脚本分享

    这篇文章主要介绍了Python实现的简单发送邮件脚本分享,本文使用smtplib模块实现邮件的发送,需要的朋友可以参考下
    2014-11-11
  • 教你pycharm快速添加远程环境的详细过程

    教你pycharm快速添加远程环境的详细过程

    今天通过本文给大家分享pycharm快速添加远程环境的过程,通过在setting中选择设置符号add,具体详细过程跟随小编一起通过本文学习下吧
    2021-07-07
  • python回调函数的使用方法

    python回调函数的使用方法

    在计算机程序设计中,回调函数,或简称回调(Callback),是指通过函数参数传递到其它代码的,某一块可执行代码的引用。这一设计允许了底层代码调用在高层定义的子程序
    2014-01-01

最新评论