Django——简单日志记录

本文介绍了Django框架中日志系统的配置与使用方法。详细解释了loggers、handlers、filters和formatters的作用,并展示了如何通过不同的配置实现日志级别的控制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Django使用Python的内置logging模块来执行系统日志记录。
主要由四部分组成:

  • loggers
    loggers 是日志系统的入口点,每一个日志都是一个以其命名的存储文件,日志信息经过处理后写入文件中
  • Handlers
  • Filters
  • Formatters

loggers 设置的有五种日志级别,日志级别描述了将要处理的消息的严重性,级别如下:

  • DEBUG
    用于调试目的的低级别系统信息
  • INFO
    一般的系统信息
  • WARNING
    描述发生的主要问题的信息
  • ERROR
    描述发生的主要问题的信息
  • CRITICAL
    描述发生的关键问题的信息

每一条写入的消息都是一条日志,每一条日志都包括有一个日志级别。

现在先假设我们已经配置了 loggers Handlers Filters 以及Formatters
下面在代码中开始调用日志模块进行日志的记录:

import logging

logger = logging.getLogger(__name__)

def index(request):
    logger.info('接收到一条请求信息:%s'%request.body)
    ...

就这样,当每次收到请求时,都会将请求数据记录下来。

下面来看看日志系统其他部分的配置(在setting文件中配置):

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'file': {
            'level': 'DEBUG',
            'class': 'logging.FileHandler',
            'filename': '/path/to/django/debug.log',
        },
    },
    'loggers': {
        'django': {
            'handlers': ['file'],
            'level': 'DEBUG',
            'propagate': True,
        },
    },
}

上面的配置是将django的所有记录写入到本地文件中,日志文件的位置需要是django程序用户可写的。

在看看另外一条配置,默认情况下django只会将日志级别不低于 INFO 的消息输出到控制台,这与 django 默认的 debug=true 日志记录不同的是,可以通过设置环境变量 DJANGO_LOG_LEVEL=DEBUG 来查看所有Django的调试日志记录

import os

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console': {
            'class': 'logging.StreamHandler',
        },
    },
    'loggers': {
        'django': {
            'handlers': ['console'],
            'level': os.getenv('DJANGO_LOG_LEVEL', 'INFO'),
        },
    },
}

基础的配置大概就是这样得了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值