Django日志

logging模块

Django的日志使用了python的logging模块,需要在settings中进行配置
logging模块由四部分组成

  • 记录器
    记录器配置具有日志级别。此日志级别描述了记录器将处理的消息的严重性。Python定义了以下日志级别:
    DEBUG: 用于调试目的的低级系统信息
    INFO: 一般系统信息
    WARNING: 描述已发生的小问题的信息。
    ERROR: 描述已发生的主要问题的信息。
    CRITICAL: 描述已发生的严重问题的信息

  • 处理器
    处理器是确定记录器中每条消息发生情况的引擎。它描述了特定的日志记录行为,例如将消息写入屏幕,文件或网络套接字。

    与记录器一样,处理器也具有日志级别。如果日志记录的日志级别未达到或超过处理程序的级别,则处理程序将忽略该消息。

    记录器可以有多个处理器,每个处理器可以具有不同的日志级别。以这种方式,可以根据消息的重要性提供不同形式的通知。

  • 过滤器
    过滤器用于提供对日志记录从记录器传递到处理程序的附加控制。

    默认情况下,将处理满足日志级别要求的任何日志消息。但是,通过安装筛选器,可以在日志记录过程中添加其他条件。例如,您可以安装仅允许ERROR发出来自特定源的消息的过滤器。

    过滤器还可用于在发出之前修改日志记录。例如,如果满足一组特定条件,您可以编写一个过滤器,将ERROR日志记录降级 为WARNING记录。

    过滤器可以安装在记录器或处理器上; 可以在链中使用多个过滤器来执行多个过滤操作。

  • 格式化程序
    最终,日志记录需要呈现为文本。格式化程序描述该文本的确切格式。格式化程序通常由包含LogRecord属性的Python格式化字符串组成 ; 但是,也可以编写自定义格式化程序来实现特定的格式化行为。

示例

  • 配置
    LOG_PATH = 'xx/xx/'
    LOGGING = {
        'version': 1,   #定义了配置文件的版本
        'disable_existing_loggers': False,  ## True表示禁用logger
        # 格式化
        'formatters': {
            'default': {
                'format': '%(levelname)s %(asctime)s %(module)s %(funcName)s %(msecs)s %(message)s'
                },
            'simple': {
                'format': '%(levelname)s %(message)s'
                },
            },
         # 处理日志的方式
        'handlers': {
            'v_handlers': {
                # 级别
                'level': 'DEBUG',
                # 存储方式
                "class": 'logging.handlers.RotatingFileHandler',
                # 日志文件大小
                'maxBytes': 5 * 1024,
                'encoding': 'utf8',
                # 日志文件路径
                'filename': '{}salary_all.log'.format(LOG_PATH),
                # 格式化方式
                'formatter': 'default',
                },
            'error': {
                'level': "ERROR",
                'class': 'logging.handlers.RotatingFileHandler',
                'maxBytes': 5 * 1024,
                'encoding': 'utf8',
                'filename': '{}salary_error.log'.format(LOG_PATH),
                'formatter': 'simple'
                }
            },
         # 配置日志的处理方式
        'loggers': {
            'django': {
                'handlers': ['v_handlers'],
                'propagate': True,
                },
            'django.request': {
                'handlers': ['error'],
                'level': 'ERROR',
                'propagate': True
                }
    
            },
         # 过滤器
        'filters': {
    
            }
        }
    
    
  • format
    format
    %(levelno)s日志的级别数字形式
    %(levelname)s日志级别的名称
    %(pathname)s当前执行程序的路径
    %(filename)s当前执行程序名
    %(funcName)s当前的函数
    %(lineno)d记录日志的当前行号
    %(asctime)s日期时间
    %(msecs)s毫秒级的时间
    %(thread)d线程ID
    %(threadName)s线程名称
    %(process)d进程ID
    %(message)s记录的日志信息

本文链接:时光不写博客-Django日志

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。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

时光不写代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值