Python實(shí)現(xiàn)日志備份守護(hù)進(jìn)程的示例
實(shí)訓(xùn)背景
假設(shè)你是一名運(yùn)維工程師,需要為公司的監(jiān)控系統(tǒng)開發(fā)一個(gè)簡(jiǎn)單的日志備份守護(hù)進(jìn)程。該進(jìn)程需滿足以下需求:
- 后臺(tái)運(yùn)行:脫離終端,長(zhǎng)期監(jiān)控指定目錄(如 /var/log/app/)中的日志文件。
- 自動(dòng)備份:每隔 5 分鐘將新增的日志文件壓縮備份到 /backup/logs/ 目錄。
- 日志記錄:記錄守護(hù)進(jìn)程自身的操作日志到 /var/log/backup_daemon.log。
- 系統(tǒng)服務(wù)化:通過(guò) systemd 管理進(jìn)程的啟動(dòng)、停止和狀態(tài)查看。
環(huán)境準(zhǔn)備
操作系統(tǒng):Ubuntu/CentOS 等主流 Linux 發(fā)行版
Python 版本:Python 3.x
依賴安裝:
# 確保已安裝 Python3 和 pip sudo apt install python3 python3-pip # Ubuntu sudo yum install python3 python3-pip # CentOS
實(shí)訓(xùn)步驟
任務(wù)1:編寫 Python 守護(hù)進(jìn)程代碼
目標(biāo):用 Python 實(shí)現(xiàn)日志監(jiān)控與備份邏輯,無(wú)需手動(dòng)處理 fork()
。
創(chuàng)建腳本 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分鐘執(zhí)行一次
任務(wù)2:配置 systemd 服務(wù)
目標(biāo):讓 Python 腳本以服務(wù)形式在后臺(tái)運(yùn)行,無(wú)需代碼內(nèi)守護(hù)進(jìn)程邏輯。
創(chuàng)建服務(wù)文件
sudo vim /etc/systemd/system/backup_daemon.service
編寫服務(wù)配置
[Unit] Description=Python Log Backup Daemon After=network.target [Service] Type=simple ExecStart=/usr/bin/python3 /path/to/backup_daemon.py # 修改為實(shí)際腳本路徑 Restart=on-failure RestartSec=5s User=root WorkingDirectory=/ # 可選:設(shè)置工作目錄 [Install] WantedBy=multi-user.target
部署并啟動(dòng)服務(wù)
sudo systemctl daemon-reload sudo systemctl start backup_daemon sudo systemctl enable backup_daemon
任務(wù)3:測(cè)試與驗(yàn)證
生成測(cè)試日志文件
sudo touch /var/log/app/test.log
查看備份結(jié)果
ls /backup/logs # 5分鐘后應(yīng)生成 test.log.tar.gz
查看守護(hù)進(jìn)程日志
tail -f /var/log/backup_daemon.log
任務(wù)4:管理服務(wù)
查看狀態(tài)
systemctl status backup_daemon
停止服務(wù)
sudo systemctl stop backup_daemon
查看 systemd 日志
journalctl -u backup_daemon -f # 實(shí)時(shí)跟蹤日志
實(shí)訓(xùn)總結(jié)
通過(guò)本案例,您將掌握:
- 使用 Python 實(shí)現(xiàn)守護(hù)進(jìn)程邏輯(無(wú)需手動(dòng)
fork()
)。 - 通過(guò)
systemd
管理 Python 腳本的后臺(tái)運(yùn)行。 - 利用 Python 的
logging
模塊記錄操作日志。
知識(shí)要點(diǎn)
Python 優(yōu)勢(shì):
- 無(wú)需處理底層
fork()
和setsid()
,代碼更簡(jiǎn)潔。 - 使用
subprocess
模塊可輕松調(diào)用系統(tǒng)命令(如tar
)。
systemd 管理:
- 通過(guò)
Type=simple
直接運(yùn)行前臺(tái)程序,systemd
自動(dòng)守護(hù)化。 - 日志可通過(guò)
journalctl
統(tǒng)一查看。
日志記錄:
- Python 內(nèi)置
logging
模塊提供靈活的日志管理。
擴(kuò)展優(yōu)化建議
- 增量備份:記錄已備份的文件名或時(shí)間戳,避免重復(fù)壓縮。
- 異常處理:增加
try/except
捕獲文件操作異常。 - 配置文件:使用
configparser
模塊管理路徑、間隔時(shí)間等參數(shù)。
到此這篇關(guān)于Python實(shí)現(xiàn)日志備份守護(hù)進(jìn)程的示例的文章就介紹到這了,更多相關(guān)Python 日志備份守護(hù)進(jìn)程內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python全棧之進(jìn)程和守護(hù)進(jìn)程
- python 如何設(shè)置守護(hù)進(jìn)程
- Python 創(chuàng)建守護(hù)進(jìn)程的示例
- Python守護(hù)進(jìn)程實(shí)現(xiàn)過(guò)程詳解
- python實(shí)現(xiàn)守護(hù)進(jìn)程、守護(hù)線程、守護(hù)非守護(hù)并行
- python使用fork實(shí)現(xiàn)守護(hù)進(jìn)程的方法
- Python如何實(shí)現(xiàn)守護(hù)進(jìn)程的方法示例
- python daemon守護(hù)進(jìn)程實(shí)現(xiàn)
- Python守護(hù)進(jìn)程用法實(shí)例分析
相關(guān)文章
Python模塊學(xué)習(xí) datetime介紹
Python提供了多個(gè)內(nèi)置模塊用于操作日期時(shí)間,像calendar,time,datetime。time模塊我在之前的文章已經(jīng)有所介紹,它提供的接口與C標(biāo)準(zhǔn)庫(kù)time.h基本一致2012-08-08python pandas中DataFrame類型數(shù)據(jù)操作函數(shù)的方法
下面小編就為大家分享一篇python pandas中DataFrame類型數(shù)據(jù)操作函數(shù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04Python實(shí)現(xiàn)的簡(jiǎn)單發(fā)送郵件腳本分享
這篇文章主要介紹了Python實(shí)現(xiàn)的簡(jiǎn)單發(fā)送郵件腳本分享,本文使用smtplib模塊實(shí)現(xiàn)郵件的發(fā)送,需要的朋友可以參考下2014-11-11教你pycharm快速添加遠(yuǎn)程環(huán)境的詳細(xì)過(guò)程
今天通過(guò)本文給大家分享pycharm快速添加遠(yuǎn)程環(huán)境的過(guò)程,通過(guò)在setting中選擇設(shè)置符號(hào)add,具體詳細(xì)過(guò)程跟隨小編一起通過(guò)本文學(xué)習(xí)下吧2021-07-07