优雅地使用loguru模块管理日志及日志文件轮转的文件名修改

优雅地使用loguru模块管理日志及日志文件轮转的文件名修改

loguru模块日志配置

loguru为开源的第三方日志库,比官方提供的logging库更易用,推荐使用。这是我自己写的loguru模块的配置,可以参考使用。

# -*- coding: utf-8 -*-
import sys

from pathlib import Path
from loguru import logger

LOG_CONFIG = {
    "handlers": [
        {
            "sink": sys.stdout,
            "level": "INFO",
            "filter": lambda record: record["extra"]["env"] == "dev",
            "format": "<green>{time:YYYY-MM-DD HH:mm:ss}</green> [<level>{level}</level>] <level>{module}:{line}</level>> <level>{message}</level>",
        },
        {
            "sink": sys.stdout,
            "level": "INFO",
            "filter": lambda record: record["extra"]["env"] == "test",
            "format": "<green>{time:YYYY-MM-DD HH:mm:ss}</green> [<level>{level}</level>] <level>{module}:{line}</level>> <level>{message}</level>",
        },
        {
            "sink": Path(__file__).resolve().parent.joinpath("log", "{time:YYYY-MM}", "{time:YYYY-MM-DD}", "dev", "pythonlog.log").__str__(),
            "level": "DEBUG",
            "filter": lambda record: record["extra"]["env"] == "dev",
            "format": "<green>{time:YYYY-MM-DD HH:mm:ss}</green> [<level>{level}</level>] <level>{module}:{line}</level>> <level>{message}</level>",
            "rotation": "10 MB",
            "retention": "60 days"
        },
        {
            "sink": Path(__file__).resolve().parent.joinpath("log", "{time:YYYY-MM}", "{time:YYYY-MM-DD}", "test", "pythonlog.log").__str__(),
            "level": "DEBUG",
            "filter": lambda record: record["extra"]["env"] == "test",
            "format": "<green>{time:YYYY-MM-DD HH:mm:ss}</green> [<level>{level}</level>] <level>{module}:{line}</level>> <level>{message}</level>",
            "rotation": "10 MB",
            "retention": "60 days"
        },
        {
            "sink": Path(__file__).resolve().parent.joinpath("log", "{time:YYYY-MM}", "{time:YYYY-MM-DD}", "dev", "error.log").__str__(),
            "level": "ERROR",
            "filter": lambda record: record["extra"]["env"] == "dev",
            "format": "<green>{time:YYYY-MM-DD HH:mm:ss}</green> [<level>{level}</level>] <level>{module}:{line}</level>> <level>{message}</level>",
            "rotation": "10 MB",
            "retention": "60 days"
        },
        {
            "sink": Path(__file__).resolve().parent.joinpath("log", "{time:YYYY-MM}", "{time:YYYY-MM-DD}", "test", "error.log").__str__(),
            "level": "ERROR",
            "filter": lambda record: record["extra"]["env"] == "test",
            "format": "<green>{time:YYYY-MM-DD HH:mm:ss}</green> [<level>{level}</level>] <level>{module}:{line}</level>> <level>{message}</level>",
            "rotation": "10 MB",
            "retention": "60 days"
        }
    ],
    "extra": {
        "env": "dev"
    }
}


logger.remove()
logger.configure(**LOG_CONFIG)


if __name__ == '__main__':
    logger.info("dev log")
    tlogger = logger.bind(env="test")
    tlogger.info("test log")

日志文件轮转的文件名修改

日志文件轮转的文件名修改需要修改loguru模块的源代码,在源代码中找到generate_rename_path(root, ext, creation_time)方法并修改即可。

# -*- coding: utf-8 -*-

def generate_rename_path(root, ext, creation_time):
    creation_datetime = datetime.datetime.fromtimestamp(creation_time)
    date = FileDateFormatter(creation_datetime)

    renamed_path = "{}.{}{}".format(root, date, ext)
    counter = 1

    while os.path.exists(renamed_path):
        counter += 1
        renamed_path = "{}.{}.{}{}".format(root, date, counter, ext)

    return renamed_path

如修改为下面的代码

# -*- coding: utf-8 -*-

def generate_rename_path(root, ext, creation_time):
    renamed_path = "{}{}".format(root, ext)
    counter = 1

    while os.path.exists(renamed_path):
        counter += 1
        renamed_path = "{}.{}{}".format(root, counter, ext)

    return renamed_path

注意

我使用的loguru库的版本为0.7.2,其它版本可能不适用

文章编写于2023年12月

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要按大小切割日志文件,可以使用 logrotate 工具来实现。logrotate 工具可以定期对指定的日志文件进行轮转,以便于管理和备份。 以下是按大小切割日志文件的步骤: 1. 安装 logrotate 工具,可以使用以下命令进行安装: ``` sudo apt-get install logrotate ``` 2. 创建一个 logrotate 配置文件,可以在 /etc/logrotate.d 目录下创建一个新的文件,例如 /etc/logrotate.d/myapp。在该文件中,可以配置需要轮转日志文件轮转周期、保存的备份数量等参数。例如: ``` /var/log/myapp.log { size 10M rotate 5 compress dateext create 0644 root root } ``` 上面的配置表示,对 /var/log/myapp.log 文件进行轮转,当文件大小达到 10M 时进行轮转,最多保存 5 个备份文件使用 gzip 进行压缩,备份文件名添加日期后缀,新建备份文件的权限为 0644,属主为 root。 3. 手动执行 logrotate 来进行日志轮转,可以使用以下命令来进行手动轮转: ``` logrotate -f /etc/logrotate.d/myapp ``` 上面的命令表示,强制执行 /etc/logrotate.d/myapp 配置文件中定义的轮转操作。 4. 配置 logrotate 定时任务,定期执行轮转操作。可以编辑 /etc/crontab 文件,添加以下行: ``` 0 0 * * * root logrotate -f /etc/logrotate.d/myapp ``` 上面的配置表示,每天午夜 0 点执行 logrotate 命令来进行日志轮转。 注意:在配置 logrotate 时,需要根据实际情况进行配置,以免误删重要的日志信息。另外,需要按照一定的规则来命名备份文件,以便于管理和查找。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值