python通過TimedRotatingFileHandler按時間切割日志
通過TimedRotatingFileHandler按時間切割日志
線上跑了一個定時腳本,每天生成的日志文件都寫在了一個文件中。但是日志信息不可能輸出到單一的一個文件中。
原因有二:1.日志文件越來越大會影響系統(tǒng)的性能。2.日志文件格式不夠清晰,比如我想看今天的日志,不太方便找到的今天的日志信息(即使對日志輸出做了時間提示)
通過設(shè)置 TimedRotatingFileHandler 進(jìn)行日志按周(W)、天(D)、時(H)、分(M)、秒(S)切割。
先看一個簡單例子:
import time
import logging
import os
from logging import handlers
def _logging(**kwargs):
level = kwargs.pop('level', None)
filename = kwargs.pop('filename', None)
datefmt = kwargs.pop('datefmt', None)
format = kwargs.pop('format', None)
if level is None:
level = logging.DEBUG
if filename is None:
filename = 'default.log'
if datefmt is None:
datefmt = '%Y-%m-%d %H:%M:%S'
if format is None:
format = '%(asctime)s [%(module)s] %(levelname)s [%(lineno)d] %(message)s'
log = logging.getLogger(filename)
format_str = logging.Formatter(format, datefmt)
# backupCount 保存日志的數(shù)量,過期自動刪除
# when 按什么日期格式切分(這里方便測試使用的秒)
th = handlers.TimedRotatingFileHandler(filename=filename, when='S', backupCount=3, encoding='utf-8')
th.setFormatter(format_str)
th.setLevel(logging.INFO)
log.addHandler(th)
log.setLevel(level)
return log
os.makedirs("./logs", exist_ok=True)
logger = _logging(filename='./logs/default.log')
if __name__ == '__main__':
while True:
time.sleep(0.1)
logger.info('哈哈哈')
結(jié)果如下:

上述代碼可以正常運行,而且也可以生成固定的日志個數(shù),但是有一個問題,生成的日志文件格式是你的 文件名+時間 的格式,沒有設(shè)置時間的話默認(rèn)設(shè)置到了秒(這里是按秒切割)
修改日志格式后綴名稱:
# 在上述代碼中加入
def namer(filename):
return filename.split('default.')
th.namer = namer
# 設(shè)置為S,默認(rèn)的suffix為 Y-%m-%d_%H-%M-%S
th.suffix = "%Y-%m-%d_%H-%M-%S.log"
# 為了看的更視覺效果,可以顯示在控制臺答應(yīng)
cmd = logging.StreamHandler()
cmd.setFormatter(format_str)
cmd.setLevel(level)
log.addHandler(cmd)
運行結(jié)果:

名字好像可以了,但是日志好像沒有起到自動刪除的目的啊,而且也沒在之前的log文件夾了。
來看看源碼:
def getFilesToDelete(self):
"""
Determine the files to delete when rolling over.
More specific than the earlier method, which just used glob.glob().
"""
dirName, baseName = os.path.split(self.baseFilename)
fileNames = os.listdir(dirName)
result = []
prefix = baseName + "."
plen = len(prefix)
for fileName in fileNames:
if fileName[:plen] == prefix:
suffix = fileName[plen:]
if self.extMatch.match(suffix):
result.append(os.path.join(dirName, fileName))
if len(result) < self.backupCount:
result = []
else:
result.sort()
result = result[:len(result) - self.backupCount]
return result
這是它的刪除邏輯,關(guān)鍵是通過 . 前面的字段判斷是否重復(fù),當(dāng)有特定的重復(fù)數(shù)后開始刪除。
所以問題來了,要么自己去重寫源碼,要么就只能用 default.日期.log 這種格式了。
附上平時使用的日志代碼
import logging
import os
from logging import handlers
def _logging(**kwargs):
level = kwargs.pop('level', None)
filename = kwargs.pop('filename', None)
datefmt = kwargs.pop('datefmt', None)
format = kwargs.pop('format', None)
if level is None:
level = logging.DEBUG
if filename is None:
filename = 'default.log'
if datefmt is None:
datefmt = '%Y-%m-%d %H:%M:%S'
if format is None:
format = '%(asctime)s [%(module)s] %(levelname)s [%(lineno)d] %(message)s'
log = logging.getLogger(filename)
format_str = logging.Formatter(format, datefmt)
def namer(filename):
return filename.split('default.')[1]
# cmd = logging.StreamHandler()
# cmd.setFormatter(format_str)
# cmd.setLevel(level)
# log.addHandler(cmd)
os.makedirs("./debug/logs", exist_ok=True)
th_debug = handlers.TimedRotatingFileHandler(filename="./debug/" + filename, when='D', backupCount=3,
encoding='utf-8')
# th_debug.namer = namer
th_debug.suffix = "%Y-%m-%d.log"
th_debug.setFormatter(format_str)
th_debug.setLevel(logging.DEBUG)
log.addHandler(th_debug)
th = handlers.TimedRotatingFileHandler(filename=filename, when='D', backupCount=3, encoding='utf-8')
# th.namer = namer
th.suffix = "%Y-%m-%d.log"
th.setFormatter(format_str)
th.setLevel(logging.INFO)
log.addHandler(th)
log.setLevel(level)
return log
os.makedirs('./logs', exist_ok=True)
logger = _logging(filename='./logs/default')
總結(jié)
以上所述是小編給大家介紹的python通過TimedRotatingFileHandler按時間切割日志,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
詳解python實現(xiàn)數(shù)據(jù)歸一化處理的方式:(0,1)標(biāo)準(zhǔn)化
這篇文章主要介紹了詳解python實現(xiàn)數(shù)據(jù)歸一化處理的方式:(0,1)標(biāo)準(zhǔn)化,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
python3 實現(xiàn)對圖片進(jìn)行局部切割的方法
今天小編就為大家分享一篇python3 實現(xiàn)對圖片進(jìn)行局部切割的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12
Python標(biāo)準(zhǔn)庫time使用方式詳解
這篇文章主要介紹了Python標(biāo)準(zhǔn)庫time使用方式詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-07-07

