Django日志logging的配置和自定义添加方式

yizhihongxing

下面我将为您详细讲解Django日志logging的配置和自定义添加方式。

配置Django日志logging

Django使用logging模块来记录日志,默认情况下,它会输出到控制台中。我们可以通过在settings.py文件中配置logging设置来自定义日志记录方式。

先看一下一个标准的logging配置示例,如下所示:

    LOGGING = {
        'version': 1,
        'disable_existing_loggers': False,
        'formatters': {
            'verbose': {
                'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'
            },
            'simple': {
                'format': '%(levelname)s %(message)s'
            },
        },
        'handlers': {
            'console': {
                'level': 'DEBUG',
                'class': 'logging.StreamHandler',
                'formatter': 'verbose'
            },
            'file': {
                'level': 'DEBUG',
                'class': 'logging.FileHandler',
                'filename': os.path.join(BASE_DIR, 'django.log'),
                'formatter': 'verbose'
            },
        },
        'loggers': {
            'django': {
                'handlers': ['console', 'file'],
                'level': 'DEBUG',
                'propagate': True,
            },
        },
    }

其中,LOGGING设置包含三个主要部分:'formatters'、'handlers'、'loggers'。

formatters

'formatters' 用于格式化输出日志内容的样式。Django默认配置两种样式:'verbose'和'simple'。
- 'verbose' 样式包括了大量日志的详细信息,如日志级别、时间、模块、进程和线程信息;
- 'simple' 样式只包含了日志级别和具体的日志信息。

handlers

'handlers' 用于定义日志处理器,Django默认配置两种处理器:'StreamHandler'和'FileHandler'。
- 'StreamHandler' 处理器将日志信息输出到控制台;
- 'FileHandler' 处理器将日志信息输出到文件。

loggers

'loggers' 用于定义日志处理方式,包括日志级别和处理器。通常情况下,我们定义一个名为'django'的默认日志处理器,并列出所有的处理器;也就是说,我们在默认情况下将所有的日志都记录到控制台和指定的文件中。

自定义添加Django日志logging方式

除了使用默认的日志设置,Django也支持自定义添加日志方式。

以下是一个自定义添加Django日志logging方式的示例,其中包含两种添加方式示例。

方式1:在views中添加日志

    import logging
    import json

    logger = logging.getLogger(__name__)

    def test(request):
        logger.warning(json.dumps({'message': 'test log'}))
        return HttpResponse("test logging")

以上示例中,我们使用了Python中内置的logging模块记录日志,首先需要 import logging模块,然后获取一个特定的logger对象。这个logger对象的名称是当前模块的名称,即__name__值。然后使用logger对象来记录日志,可使用debug()、info()、warning()、 error()、critical()五种方法中的任何一种。在此示例中,我们使用了warning方法。

方式2:在middleware中添加日志

    import logging
    import time

    logger = logging.getLogger(__name__)

    class LoggingMiddleware(object):

        def process_request(self, request):
            self.start_time = time.time()
            return None

        def process_response(self, request, response):
            elapsed_time = time.time() - self.start_time
            content = response.content
            content = content.decode('utf-8')
            if response.status_code == 200 and len(content) < 1000:
                logger.info("{time:.5f}s \n{content}".format(content=content, time=elapsed_time))
            else:
                logger.warning("{method} {url} {status_code} {time:.5f}s".format(
                    method = request.method,
                    url = request.build_absolute_uri(),
                    status_code = response.status_code,
                    time = elapsed_time,
                ))
            return response

以上示例中,我们新建了一个middleware LoggingMiddleware,在此类中重写了process_request和process_response方法。它可以捕获所有的请求和响应,用函数计算并记录耗时,并将响应内容写入日志文件或输出到控制台。

总结

以上就是Django日志logging的配置和自定义添加方式的详细攻略。配置logging,可以帮助我们记录、追踪和排除应用程序运行中出现的各种问题,并定制各自的日志信息输出方式。添加自定义日志方式,可以实现更加灵活、强大的日志记录功能。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Django日志logging的配置和自定义添加方式 - Python技术站

(0)
上一篇 2023年5月15日
下一篇 2023年5月15日

相关文章

  • Django笔记九之model查询filter、exclude、annotate、order_by

    在接下来四五篇笔记中,将介绍 model 查询方法的各个细节,为我们的查询操作提供各种便利。 本篇笔记将介绍惰性查找、filter、exclude、annotate等方法,目录如下: 惰性查找 filter exclude annotate alias order_by 1、惰性查找 前面我们在介绍 Django 增删改查的时候,提到过他的惰性查找的规则。 …

    2023年4月10日
    00
  • django web 中添加超链接

    django web 中添加不传参的超链接的方法如下: html: 在web中的超链接中加入一下url     <a href=”{% url ‘app_name.views.url_func’ %}”></a> {% url %}标签中的app_name为应用名,url_func为urls中的函数名;   urls.py 在模板中加…

    Django 2023年4月10日
    00
  • 使用django实现一个代码发布系统

    使用Django实现一个代码发布系统的完整攻略,可以大致分为以下几个步骤: 创建Django项目和应用程序 定义数据模型 创建视图和模板 添加表单 实现文件上传和保存 集成代码发布功能 下面会逐步详细说明。 创建Django项目和应用程序 首先,使用Django的命令行工具 django-admin 创建项目: $ django-admin startpro…

    Django 2023年5月16日
    00
  • Django中ORM基本应用与原理解析

    Django中ORM基本应用与原理解析 什么是ORM ORM(Object-relational mapping),即对象关系映射,是一种程序设计技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换(ORM技术对应的是关系型数据库)。简单来说,ORM就是一种通过操作对象而非数据库表来操作数据库的技术。 Django的ORM是关系型数据库操作的一个工具…

    Django 2023年5月16日
    00
  • ubuntu下Django的下载与安装(三种方法)

    方法一: 1下载: 1 安装python,Linux系统下,一般是安装好的,可以输入如下命令查看  python -V 如果没有安装,则需要安装,安装方法如下,首先从官网下载源码,然后: (1) $ tar -jxvf Python-x.y.z.tar.bz2 (2) $ cd Python-x.y.z (3) $ ./configure (4) $ mak…

    Django 2023年4月11日
    00
  • django rest framework暴露api

    一、创建序列化模型文件serializers.py class Course(models.Model): “”” 课程 “”” title = models.CharField(verbose_name=”课程名称”, max_length=128) course_img = models.CharField(verbose_name=”课程图片”, ma…

    Django 2023年4月11日
    00
  • Python Django 实现简单注册功能过程详解

    下面我将详细讲解“Python Django 实现简单注册功能过程”的完整攻略。本攻略分为以下几个部分: 创建 Django 项目和应用 安装、配置和使用 Django 自带的认证系统 自定义认证系统 实现简单注册功能 示例一:使用 Django 自带的认证系统实现注册和登录功能 示例二:自定义认证系统实现注册和登录功能 1. 创建 Django 项目和应用…

    Django 2023年5月16日
    00
  • [DJANGO] excel十几万行数据快速导入数据库研究

    先贴原来的导入数据代码: 8 import os os.environ.setdefault(“DJANGO_SETTINGS_MODULE”, “www.settings”) ”’ Django 版本大于等于1.7的时候,需要加上下面两句 import django django.setup() 否则会抛出错误 django.core.exception…

    Django 2023年4月10日
    00
合作推广
合作推广
分享本页
返回顶部