欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實(shí)現(xiàn)日志備份守護(hù)進(jìn)程的示例

 更新時(shí)間:2025年04月18日 09:23:16   作者:漫談網(wǎng)絡(luò)  
本文主要介紹了Python實(shí)現(xiàn)日志備份守護(hù)進(jìn)程的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

實(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)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • pyecharts結(jié)合flask框架的使用

    pyecharts結(jié)合flask框架的使用

    這篇文章主要介紹了pyecharts結(jié)合flask框架,主要是介紹如何在Flask框架中使用pyecharts,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • Python中serial庫(kù)的介紹及用法示例

    Python中serial庫(kù)的介紹及用法示例

    Python的serial庫(kù)是一個(gè)用于串口通信的Python擴(kuò)展庫(kù),它提供了許多方法和功能,用于控制和配置串行端口以及讀取和寫入串行數(shù)據(jù),這篇文章主要給大家介紹了關(guān)于Python中serial庫(kù)用法的相關(guān)資料,需要的朋友可以參考下
    2024-07-07
  • 舉例介紹Python中的25個(gè)隱藏特性

    舉例介紹Python中的25個(gè)隱藏特性

    這篇文章主要介紹了一些Python中的隱藏特性,從stackoverflow的人氣問(wèn)題回答中整理而來(lái),主要以代碼實(shí)際解釋說(shuō)明,需要的朋友可以參考下
    2015-03-03
  • Python模塊學(xué)習(xí) datetime介紹

    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-08
  • python類方法和靜態(tài)方法詳解

    python類方法和靜態(tài)方法詳解

    這篇文章主要為大家介紹了python類方法和靜態(tài)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-01-01
  • python pandas中DataFrame類型數(shù)據(jù)操作函數(shù)的方法

    python pandas中DataFrame類型數(shù)據(jù)操作函數(shù)的方法

    下面小編就為大家分享一篇python pandas中DataFrame類型數(shù)據(jù)操作函數(shù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • Python jieba結(jié)巴分詞原理及用法解析

    Python jieba結(jié)巴分詞原理及用法解析

    這篇文章主要介紹了Python jieba結(jié)巴分詞原理及用法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Python實(shí)現(xiàn)的簡(jiǎn)單發(fā)送郵件腳本分享

    Python實(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ò)程

    教你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
  • python回調(diào)函數(shù)的使用方法

    python回調(diào)函數(shù)的使用方法

    在計(jì)算機(jī)程序設(shè)計(jì)中,回調(diào)函數(shù),或簡(jiǎn)稱回調(diào)(Callback),是指通過(guò)函數(shù)參數(shù)傳遞到其它代碼的,某一塊可執(zhí)行代碼的引用。這一設(shè)計(jì)允許了底層代碼調(diào)用在高層定義的子程序
    2014-01-01

最新評(píng)論