2021-08-03-DJ-023 django日志配置与解析

2023-10-24 19:33

本文主要是介绍2021-08-03-DJ-023 django日志配置与解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

日志
官方 文档 对日志的描述

1.常见配置

#日志配置区,LOGGING
LOGGING={'version':1,'formatters':{'simple':{'format':'[%(asctime)s %(name)s] %(message)s','datefmt':'%Y-%m-%d %H:%M:%S'}},'handlers':{'out':{'class':'logging.StreamHandler','formatter':'simple','level':'DEBUG'},'file':{'class':'logging.FileHandler','formatter':'simple','level':'INFO','filename':'mylog.log'}},'loggers':{'django':{'handlers':['out','file'],'level':'DEBUG','propagate':True},'mylog':{'handlers':['file'],'level':'INFO','propagate':True},}
}

2.内容分析

2.1组成部分

LOGGING配置常有下面四个部分组成:
Formatters:格式化
Handlers:处理器
Loggers:记录器
Filters:过滤器

2.2详细介绍 上面的配置

LOGGING={ 日 志设置的标准名称
‘version’:1.0, 版本
‘formatters’:{ 一、 格式化部分
‘simple’:{ 一种格式的名称
‘format’:’[%(asctime)s %(name)s] %(message)s’, 输出格式,括号内是参数,%s是字符串格式
‘datefmt’:’%Y-%m-%d %H:%M:%S’ 日期格式
}
},
‘handlers’:{ 二、处理器部分
‘out’:{ 一个处理器的名称,名称 都可以自己编
‘class’:‘logging.StreamHandler’,
‘formatter’:‘simple’, 格式选simple
‘level’:‘DEBUG’ 日志处理的级别:DEBUG:排查故障时使用的低级别系统信息

    },'file':{                        一个处理器名称'class':'logging.FileHandler','formatter':'simple',                  格式选simple'level':'INFO',							日志处理的级别:INFO:一般的系统信息'filename':'mylog.log'              存储文件名}
},
'loggers':{                            三、记录器部分'django':{												一个记录器名字'handlers':['out','file'],						这个记录器包含的处理器列表'level':'DEBUG',								日志记录级别,等同于os.getenv('DJANGO_LOG_LEVEL', 'INFO'),'propagate':True                              传播},'mylog':{                                              一个记录器名字'handlers':['file'],                             这个记录器包含的处理器列表'level':'INFO',                                日志记录的级别'propagate':True                           传播},}

}

2.3日志级别

日志级别表示只有这个级别以上的消息系统才提示
日志级别有:
DEBUG:排查故障时使用的低级别系统信息
INFO:一般的系统信息
WARNING:描述系统发生了一些小问题的信息
ERROR:描述系统发生了大问题的信息
CRITICAL:描述系统发生严重问题的信息
禁用默认的日志配置,在settings中设置

LOGGING_CONFIG = None
或者在LOGGING中 加 disable_existing_loggers 键为 True

handlers 里面的class有哪些请参考:【Python基础】Python模块之Logging(四)——常用handlers的使用

propagate是传播, 是否让日志信息继续冒泡给其他的日志处理系统,子级向父级传播
对日志的参数介绍的比较好的一篇博客是这个Django中的日志详解。

3.框架中操作

自己引发日志 记录
配置好日志记录参数后在上节做的中间件里做这件事情

import logging
class LoginCheckMiddleware(MiddlewareMixin):def process_request(self,request):print('login_checkMiddleware,request',request.path,request.META['REMOTE_ADDR'])excludelist=['/main/login','/main/imgcode']if request.path not in excludelist:#验证 用户是否已经登录if not request.COOKIES.get('token'):ip=request.path,request.META['REMOTE_ADDR']path=request.get_raw_uri()msg='%s->%s'%(ip,path)logging.getLogger('mylog').warning(msg)return HttpResponseRedirect('/main/login')
            logging.getLogger('mylog').warning(msg)

这句话表示用mylog记录器,打印一个warning级别的消息,在这个记录器里面,是以文件的形式的,所以消息会在日志文件里记录

我们现在去浏览器中触发这个消息

在这里插入图片描述

里面的三条warning就是以我们自定义的方式触发的

这篇关于2021-08-03-DJ-023 django日志配置与解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/277311

相关文章

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

如何在Mac上安装并配置JDK环境变量详细步骤

《如何在Mac上安装并配置JDK环境变量详细步骤》:本文主要介绍如何在Mac上安装并配置JDK环境变量详细步骤,包括下载JDK、安装JDK、配置环境变量、验证JDK配置以及可选地设置PowerSh... 目录步骤 1:下载JDK步骤 2:安装JDK步骤 3:配置环境变量1. 编辑~/.zshrc(对于zsh

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华