Python logging.handlers模块,RotatingFileHandler、TimedRotatingFileHandler 处理器各参数详细介绍
Python logging.config模块,logging.config.fileConfig()、logging.config.dictConfig() 使用介绍
python logging模块Filters过滤器介绍,如何使用自定义的过滤器
这篇文章将介绍如何在logging.config.dictConfig()
日志配置方式下,使用自定义的Handler
处理程序。
一、基于 RotatingFileHandler 的自定义处理程序
默认情况下,使用logging.handlers.RotatingFileHandler()
生成的备份文件,不是以.log
为后缀,例如:原日志文件为rotated.log
,那么生成的备份日志文件为rotated.log.xxx
,xxx
为数字。
接下来将使用自定义处理程序,将生成的备份日志文件的后缀改为rotated.xxx.log
rtfHandler.py
自定义处理程序模块
# -*- coding:utf-8 -*-
import logging
import logging.handlers
import os
import re
def my_rotating_file_handler(filename,mode='a',maxBytes=0,backupCount=0,encoding=None,delay=False):
rh = logging.handlers.RotatingFileHandler(
filename,
mode=mode,
maxBytes=maxBytes,
backupCount=backupCount,
encoding=encoding,
delay=delay
)
global bckCount # 声明全局变量,供 remove_old_log()、rotator() 方法使用
bckCount = backupCount
# 调用新实现的备份日志文件命名规则
rh.rotator = rotator
rh.namer = namer
return rh
def namer(name):
# 在备份文件后增加 .log 后缀
name = name + '.log'
return name
def rotator(source, dest):
global dest_file # 声明全局变量,供 remove_old_log() 方法使用
dest_file = dest
sp = dest.rsplit(".",3)
sp.pop(1) # 删除备份文件中间的那个".log"
# 因为改了备份日志文件名称规则,所以原有的备份规则失效了,下面是重写的备份规则
for dst in range(bckCount,0,-1):
sp[1] = str(dst)
dest = ".".join(sp)
if os.path.exists(dest):
os.remove(dest)
sp[1] = str(dst-1)
src = ".".join(sp)
if os.path.exists(src):
os.rename(src,dest)
sp[1] = str(