一.Django日志 Django使用python内建的logging模块打印日志,Python的logging配置由四个部分组成: 1.记录器(Logger) 2.处理程序(Handler) 3.过滤器(Filter) 4.格式化(Formatter) 二、Logger 记录器
一.Django日志Django使用python内建的logging模块打印日志,Python的logging配置由四个部分组成: 1>.记录器(Logger) 2>.处理程序(Handler) 3>.过滤器(Filter) 4>.格式化(Formatter) 二、Logger 记录器Logger 是日志系统的入口。每个 logger 都是命名了的 bucket, 消息写入 bucket 以便进一步处理。 Logger 可以配置 日志级别。日志级别描述了由该 logger 处理的消息的严重性。Python 定义了下面几种日志级别:
每一条写入 logger 的消息都是一条 日志记录。每一条日志记录也包含 日志级别,代表对应消息的严重程度。日志记录还包含有用的元数据,来描述被记录的事件细节,例如堆栈跟踪或者错误码。 当 logger 处理一条消息时,会将自己的日志级别和这条消息的日志级别做对比。如果消息的日志级别匹配或者高于 logger 的日志级别,它就会被进一步处理。否则这条消息就会被忽略掉。 当 logger 确定了一条消息需要处理之后,会把它传给 Handler。 Django 内置记录器
三、Handler 处理程序Handler 是决定如何处理 logger 中每一条消息的引擎。它描述特定的日志行为,比如把消息输出到屏幕、文件或网络 socket。 和 logger 一样,handler 也有日志级别的概念。如果一条日志记录的级别不匹配或者低于 handler 的日志级别,对应的消息会被 handler 忽略。 一个 logger 可以有多个 handler,每一个 handler 可以有不同的日志级别。这样就可以根据消息的重要性不同,来提供不同格式的输出。例如,你可以添加一个 handler 把 ERROR 和 CRITICAL 消息发到寻呼机,再添加另一个 handler 把所有的消息(包括 ERROR 和 CRITICAL 消息)保存到文件里以便日后分析。 Logging 自身携带Handlerlogging模块提供了一些处理器,可以通过各种方式处理日志消息。
注意:由于内置处理器还有很多,如果想更深入了解。可以查看官方手册。 四、Filter过滤器在日志从 logger 传到 handler 的过程中,使用 Filter 来做额外的控制。 默认情况下,只要级别匹配,任何日志消息都会被处理。不过,也可以通过添加 filter 来给日志处理的过程增加额外条件。例如,可以添加一个 filter 只允许某个特定来源的 ERROR 消息输出。 Filter 还被用来在日志输出之前对日志记录做修改。例如,可以写一个 filter,当满足一定条件时,把日志记录从 ERROR 降到 WARNING 级别。 Filter 在 logger 和 handler 中都可以添加;多个 filter 可以链接起来使用,来做多重过滤操作。 五、Formatters格式化器日志记录最终是需要以文本来呈现的。Formatter 描述了文本的格式。一个 formatter 通常由包含 LogRecord attributes 的 Python 格式化字符串组成,不过你也可以为特定的格式来配置自定义的 formatter。
时间格式参数:
六:Django 集成日志logginger 模块1、在项目setting.py 文件中,配置logginger 日志, 核心代码如下:
2、应用中添加logginger 日志记录 1、在应用的views.py 文件中添加logging 模块依赖,并在相关方法中输出相关日志记录
注意:在logginer 配置文件中,定义自定义记录器mylogger 对应实例化对象就是views.py 文件中实例的logging对象。 3、日志记录结果展示: |
2019-06-18
2019-07-04
2021-05-23
2021-05-27
2021-05-27