django日志文件配置

配置Django的LOGGING‌:‌

在项目的‌settings.py‌文件中添加‌LOGGING‌配置。‌这个配置项是一个字典,‌主要包含以下几个关键部分:‌
‌version‌:‌日志配置的版本号,‌当前Django仅支持1。‌
‌disable_existing_loggers‌:‌是否禁用已经存在的日志器,‌一般设置为False。‌
‌handlers‌:‌定义日志处理器,‌指定日志消息的目的地和日志级别。‌
‌loggers‌:‌定义日志记录器,‌指定日志的最小级别和使用的处理器。‌
‌formatters‌:‌定义日志的输出格式,‌包括时间、‌日志级别、‌消息等信息。‌

# 日志添加颜色
from colorlog import ColoredFormatter

# 日志记录
LOGGING = {
    "version": 1,
    "disable_existing_loggers": False,  # 用于确定在应用新的日志配置时是否禁用之前配置的日志器

    # 格式器
    "formatters": {
        "verbose": {  # 输出日志级别名称、日志信息,以及生成日志信息的时间、进程、线程和模块。format格式化输出
            "format": "{levelname} {asctime} {module} {process:d} {thread:d} {message}",
            "style": "{",
        },
        "simple": {  # 输出日志级别名称和日志信息。
            "format": "{levelname} {message}",
            "style": "{",
        },
        'color': {
            '()': ColoredFormatter,
            'format': '%(log_color)s%(levelname)-8s%(reset)s %(white)s%(message)s',
            'datefmt': '%Y-%m-%d %H:%M:%S',
            'log_colors': {
                'DEBUG': 'cyan',
                'INFO': 'green',
                'WARNING': 'yellow',
                'ERROR': 'red',
                'CRITICAL': 'red,bg_white',
            },
            'secondary_log_colors': {},
            'style': '%'
        },
    },

    # 过滤器
    "filters": {
        "require_debug_true": {
            "()": "django.utils.log.RequireDebugTrue",  # 当DEBUG为True时,传递记录。
        },
    },

    # 处理器
    "handlers": {
        "console": {  # 输出到终端
            "level": "DEBUG",  # 日志级别
            "filters": ["require_debug_true"],  # 使用的过滤器,上边已经定义
            "class": "logging.StreamHandler",  # 用于将日志消息发送到一个流,通常是一个输出流,比如控制台(标准输出)
            "formatter": "simple",  # 格式器,上边有定义
        },
        "file": {  # 输出到文件
            "level": "DEBUG",  # 日志级别
            "class": "logging.handlers.RotatingFileHandler",  # 将日志输出到一个文件中
            "filename": os.path.join(BASE_DIR, 'logs/logs.log'),  # 日志输出的文件, os.path.join用来拼接路径
            "maxBytes": 300 * 1024 * 1024,  # 一个文件300M
            "backupCount": 10,  # 备份10个文件
            "formatter": "verbose",  # 格式器
            'encoding': 'utf-8'
        },
    },
    "loggers": {  # 日志器
        "django": {  # 创建的日志记录器
            "handlers": ["console", 'file'],  # 处理方式:在终端输出、输出到文件
            "propagate": True,  # 日志没有被处理,日志消息将向上传递给上级记录器
            'level': 'DEBUG',  # 日志输出最低级别,低于这个将不会输出
        },
    },
}

Django日志配置可以在 settings.py 文件中进行配置,具体步骤如下: 1. 导入 logging 模块: ```python import logging ``` 2. 配置日志的格式: ```python LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'console': { 'class': 'logging.StreamHandler', }, 'file': { 'class': 'logging.handlers.RotatingFileHandler', 'filename': 'django.log', 'maxBytes': 1024 * 1024 * 5, # 5 MB 'backupCount': 5, }, }, 'loggers': { 'django': { 'handlers': ['console', 'file'], 'level': 'DEBUG', }, }, } ``` 在上面的配置中,使用了一个 RotatingFileHandler,将日志输出到一个名为 django.log 的文件中。maxBytes 和 backupCount 参数用于控制日志文件的大小和数量。当日志文件大小超过 maxBytes 时,会自动创建一个新的日志文件,并将旧的日志文件备份到一个新的文件中。 3. 在代码中使用日志: ```python import logging logger = logging.getLogger('django') def my_view(request): logger.debug('This is a debug message') logger.info('This is an info message') logger.warning('This is a warning message') logger.error('This is an error message') logger.critical('This is a critical message') ``` 在上面的代码中,通过 getLogger 方法获取名为 django 的 Logger 对象,并使用其 debug、info、warning、error 和 critical 方法输出不同级别的日志信息。 注意:在上面的配置中,使用了一个名为 django 的 logger,这是 Django 默认使用的 logger。如果你想要使用一个不同的 logger,需要在配置中添加对应的 handlers 和 loggers。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值