Django日志

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: logging模块Django的日志使用了python的logging模块,需要在settings中进行配置logging模块由四部分组成记录器 记录器配置具有日志级别。此日志级别描述了记录器将处理的消息的严重性。

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日志

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
17天前
|
存储 监控 数据库
Django 后端架构开发:高效日志规范与实践
Django 后端架构开发:高效日志规范与实践
34 1
|
2月前
|
Python
Django日志配置(4)
【7月更文挑战第4天】在Django中配置日志的方法非常简单,只需要在 setting 文件中添加配置项,系统会自动生成相应的日志文件,也可以配置调试时显示内容,报错发送邮件等操作。
53 0
|
4月前
|
SQL Python BI
Django实践-07日志调试,Django-Debug-Toolbar配置与sql优化
Django实践-07日志调试,Django-Debug-Toolbar配置与sql优化
Django实践-07日志调试,Django-Debug-Toolbar配置与sql优化
|
JSON API 数据安全/隐私保护
【Django学习】(十五)API接口文档平台_项目流程分析_日志器_认证_授权
【Django学习】(十五)API接口文档平台_项目流程分析_日志器_认证_授权
|
中间件 开发工具 git
【Django | 开发】面试招聘信息网站(配置中间件记录响应耗时日志)
【Django | 开发】面试招聘信息网站(配置中间件记录响应耗时日志)
【Django | 开发】面试招聘信息网站(配置中间件记录响应耗时日志)
【Django | 开发】面试招聘信息网站(增加csv,excel导出&日志管理功能)
【Django | 开发】面试招聘信息网站(增加csv,excel导出&日志管理功能)
【Django | 开发】面试招聘信息网站(增加csv,excel导出&日志管理功能)
|
SQL 数据库 Python
Django打印ORM执行sql语句日志
Django打印ORM执行sql语句日志
589 0
|
安全 Python
解决 Django 多进程下,logging 记录日志错乱问题
之前写过一篇文章 Django 中如何优雅的记录日志,本以为代码上线之后,就可以愉快的看日志,通过日志来分析问题了,但现实总是跟想象不同,两个异常现象纷纷挥起大手,啪啪地打在我的脸上。
612 0
|
中间件 Python
Django 中如何优雅的记录日志
日志是个好东西,但却并不是所有人都愿意记,直到出了问题才追悔莫及,长叹一声,当初要是记日志就好了。 但记日志却是个技术活,不能什么都不记,但也不能什么都记。如果记了很多没用的信息,反而给查日志排错的过程增加很多困难。
479 0