Python logger:limit日志文件似乎没有限制我的fi

2024-05-15 16:11:44 发布

您现在位置:Python中文网/ 问答频道 /正文

所以我想限制我的log文件

import logging
import colorlog
from logging.handlers import RotatingFileHandler

def init_logger(dunder_name, testing_mode) -> logging.Logger:
    log_format = '[%(asctime)s]: [%(levelname)s]: %(message)s'

    bold_seq = '\033[1m'
    colorlog_format = (
        f'{bold_seq} '
        '%(log_color)s '
        f'{log_format}'
    )

    logFile = 'app.log'
    colorlog.basicConfig(format=colorlog_format)

    handler = RotatingFileHandler(logFile, mode='a', maxBytes=50, backupCount=0, encoding=None, delay=0)
    logger = logging.getLogger(dunder_name)

    if testing_mode:
        logger.setLevel(logging.DEBUG)
    else:
        logger.setLevel(logging.INFO)

    formatter = logging.Formatter(log_format)
    handler.setFormatter(formatter)
    logger.addHandler(handler)


    return logger

在define maxBytes=50之后,我看到我的日志文件继续增长(4MB此时)

我做错了什么


Tags: 文件nameimportlogformatmodelogginglogger
1条回答
网友
1楼 · 发布于 2024-05-15 16:11:44

因为backupCount0

Rollover occurs whenever the current log file is nearly maxBytes in length; but if either of maxBytes or backupCount is zero, rollover never occurs, so you generally want to set backupCount to at least 1, and have a non-zero maxBytes.

https://docs.python.org/3/library/logging.handlers.html#logging.handlers.RotatingFileHandler

相关问题 更多 >