Django配置日志系统的最佳实践

   


概要

日志是跟踪应用行为、监控错误、性能分析和安全审计的重要工具。在Django框架中,合理配置日志系统可以帮助开发者有效管理项目运行过程中的关键信息。本文将详细介绍Django日志系统的最佳实践。


日志系统概述

Django使用Python的 logging 模块来实现日志系统。logging 模块强大且灵活,提供了多个级别的日志记录,不同的日志处理器(Handler),以及日志格式化工具。日志级别包括:

  • DEBUG:用于调试信息,如程序中变量的值。

  • INFO:用于记录常规操作,如登录、退出。

  • WARNING:用于潜在的问题提示。

  • ERROR:用于记录错误事件,但应用程序还能继续运行。

  • CRITICAL:用于严重的错误事件,可能会导致程序中断。

配置日志

在Django项目的 settings.py 文件中配置日志系统。以下是一个配置示例:

LOGGING = {'version': 1,'disable_existing_loggers': False,'formatters': {'verbose': {'format': '{levelname} {asctime} {module} {message}','style': '{',},'simple': {'format': '{levelname} {message}','style': '{',},},'handlers': {'file': {'level': 'DEBUG','class': 'logging.FileHandler','filename': 'debug.log','formatter': 'verbose',},'console': {'level': 'INFO','class': 'logging.StreamHandler','formatter': 'simple',},},'loggers': {'django': {'handlers': ['file', 'console'],'level': 'INFO',},},
}

这个配置定义了两个处理器:一个将日志写入debug.log文件,另一个将输出到控制台。同时指定了两种格式化方式,并为Django的日志器设置了处理器和级别。

日志记录

日志的记录非常简单。在你的Django应用中,你可以这样记录日志:

import logginglogger = logging.getLogger(__name__)def my_view(request):logger.info('处理请求 %s', request.path)try:# ... 你的业务逻辑 ...except Exception as e:logger.error('处理请求时发生错误:%s', e, exc_info=True)# ...

这段代码中,通过 getLogger() 函数获取了一个日志器,日志器的名称是当前模块的名字。然后,在视图函数中使用不同的日志级别记录信息。

日志记录和错误追踪

Django提供了django.request 日志器来记录所有与请求处理相关的活动。你可以像下面这样配置这个日志器,并记录异常信息:

LOGGING = {
# ... 其他配置保持不变 ...'loggers': {'django.request': {'handlers': ['file'],'level': 'ERROR','propagate': True,},# ... 其他日志器配置 ...},
}

这样配置后,任何未被视图捕获的异常都会被记录到指定的文件中。

日志处理器Handlers

处理器决定了日志的去向。常用的处理器有:

  • logging.StreamHandler: 输出日志到控制台。

  • logging.FileHandler: 将日志写入文件。

  • logging.handlers.RotatingFileHandler: 写入文件,并在文件达到指定大小后轮换。

  • logging.handlers.TimedRotatingFileHandler: 根据时间自动轮换日志文件。

以下是一个 RotatingFileHandler 的配置例子:

'handlers': {'file': {'level': 'DEBUG','class': 'logging.handlers.RotatingFileHandler','filename': 'debug.log','maxBytes': 1024*1024*5,  # 5 MB'backupCount': 5,'formatter': 'verbose',},# ... 其他处理器配置 ...
},

这个配置会在日志文件到达5MB时创建一个新文件,并限制备份文件的数量为5个。

编写自定义日志处理器

如果内置的处理器不能满足需求,你可以创建自己的处理器。例如,你可能想要把错误信息发送到一个在线错误追踪服务,比如Sentry:

import logging
from sentry_sdk import capture_messageclass SentryHandler(logging.Handler):def emit(self, record):if record.levelno >= logging.ERROR:capture_message(self.format(record))LOGGING = {'version': 1,# ... 其他配置保持不变 ...'handlers': {'sentry': {'level': 'ERROR','class': 'path.to.your.SentryHandler',},# ... 其他处理器配置 ...},# ...
}

在这个例子中,SentryHandler 会将 ERROR 级别及以上的日志信息发送到Sentry服务。

结论

合理配置并有效使用日志系统对于任何Django项目都是至关重要的。通过遵循本文描述的最佳实践,你可以确保你的应用能有效地记录、管理和利用日志数据。记住审视你的需求,并根据项目需求调整日志的配置。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/607142.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

掌握Lazada API接口:开启电商开发新篇章,引领业务增长潮流

一、概述 Lazada API接口是Lazada平台提供的软件开发工具包,它允许第三方开发者通过编程方式访问Lazada平台上的商品、订单、用户等数据,并执行相关操作。通过使用Lazada API接口,开发者可以快速构建与Lazada平台集成的应用程序,…

WPF 基础入门(资源字典)

资源字典 每个Resources属性存储着一个资源字典集合。如果希望在多个项目之间共享资源的话,就可以创建一个资源字典。资源字段是一个简单的XAML文档,该文档就是用于存储资源的,可以通过右键项目->添加资源字典的方式来添加一个资源字典文件…

【设计模式】一文理解记住设计模式的原则

目录——阅读所需预计5-10分钟 🎖️前言🎯单一职责原则📣1. 定义💞2. 定义很抽象,咱继续看🎉3. 举几个栗子💞4. 以上栗子出现了一个问题,单一职责的划分究竟可以分多细👉…

【花艺电商】SpringBoot集成MyBatis-Plus、Swagger2、SpringSecurity、OAuth2等技术整合开发

目录 一、功能介绍 1. 说明 2. 功能实现 3. 技术应用 二、技术详述 1.MyBatis-Plus 主要体现 项目应用 2.SpringSecurity 应用作用 三、页面展示 1. 登入 2. 主页 3. 详情 4. 购物车 5. 订单 6. 沙箱支付 每篇一获 一、功能介绍 1. 说明 这个项目主要使用了…

基于SSM的校园线上订餐系统设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:vue\html 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目:是…

OpenHarmony基于HDF简单驱动开发实例

背景 OpenHarmony-3.0-LTSqemu_small_system_demoliteos_aqemu 添加配置 device/qemu/arm_virt/liteos_a/hdf_config/device_info/device_info.hcs device_info 新增: sample_host :: host {hostName "sample_host";sample_device :: device {devic…

ASP.NET中小型超市管理系统源码

ASP.NET中小型超市管理系统源码 超市管理系统是专门为中小型超市打造的管理系统,可以方便管理时更加准确清晰的查看商品信息, 仓库出售与进货的信息,还有每一个部门员工的信息,也更加直观的体现出每一阶段的商品销售情况&#xf…

【VUE】无法加载文件 \node\vue.ps1,因为在此系统上禁止运行脚本。问题解决

问题描述 在VS Code中输入vue create -p dcloudio/uni-preset-vue uniapp-demo命令时报错 无法加载文件 D:\address\node\vue.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID135170 中的 about_Executi…

(aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器

1. 背景介绍 在先前的博客文章中,我们已经搭建了一个基于SRS的流媒体服务器。现在,我们希望通过Web接口来控制这个服务器的行为,特别是对于正在进行的 RTSP 转码任务的管理。这将使我们能够在不停止整个服务器的情况下,动态地启动…

UE5 使用动画模板创建多个动画蓝图

我们制作游戏的时候,角色会根据不同的武器表现出来不同的攻击动画,待机动画以及移动动画。如果我们在UE里面实现这个需求,是通过复制粘贴的方式修改,还是有更好的方式。 这里就需要介绍一下动画模板,我们可以将动画蓝图…

pycharm调整漂亮的颜色主题

主题样式: 一、设置主题为白色 二、pycharm 如何设置字体颜色 打开pycharm编辑器,file > settings > editor > color scheme > python > 你也可以直接用我资源中的配置好的文件

探索C语言中的水仙花数及其计算方法

在计算机科学与数学的交叉领域中,有一种特殊的整数被称为“水仙花数”,它是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个典型的水仙花数,因为1 5 3 1 125 27 153。 下面,我们通过一段…

1.7数算PPT选择汇总,PTA选择汇总,计算后缀表达式,中缀转后缀、前缀、快速排序

PTA选择汇总 在第一个位置后插入,注意是在后面插入,而不是前面;要移动49,为50-I,第25个的话,移25个 如果是插在前面,就移动50,N-I1,注意是插在前面还是后面 删第一个&a…

虾皮上传产品软件:如何使用虾皮平台上传产品

在虾皮(Shopee)平台上,卖家可以通过多种方法来上传产品,以简化商品上架过程。本文将介绍一些常用的产品上传方法,帮助卖家选择最适合自己的方式。 先给大家推荐一款shopee知虾数据运营工具 知虾免费体验地址&#xff…

【Axure高保真原型】日期天数加减计算器

今天和大家分享日期天数加减计算器的原型模板,我们通过这个模板选择指定日期,然后填写需要增加或者减少的天数,点击确认按钮后,就可以计算出对应的结束日期,本案例提供中继器版的日期选择器,以及JS版的日期…

在docker中搭建部署clickhouse

因需要给网关日志拉取并存储供数据分析师分析,由于几十个项目的网关请求数量很大,放在mysql不合适,MongoDB不适合分析,于是准备存放在clickhouse,clickhouse对于读写支持也比较友好,说干就干 1、在服务器中…

LUT预设.cube格式PR/达芬奇/FCP/剪映等视频电影调色预设LUTs

对于将标准镜头转换为让人想起高端电影的视觉冲击场景至关重要。这些LUT经过专业设计,以模仿电影行业中的电影质量、深度和情感,使其成为电影制作人、摄像师和内容创作者的理想选择,希望为你的作品带来专业的电影色彩。 电影LUT的类别&#…

STL标准库与泛型编程(侯捷)笔记4

STL标准库与泛型编程(侯捷) 本文是学习笔记,仅供个人学习使用。如有侵权,请联系删除。 参考链接 Youbute: 侯捷-STL标准库与泛型编程 B站: 侯捷 - STL Github:STL源码剖析中源码 https://github.com/SilverMaple/STLSourceCo…

【Electron】 Vite项目 初始配置 scss

pnpm add -D sasssrc下面创建 styles/main.scss 文件 mian.ts 内引入 ./styles.scss 文件 import ./styles/main.scss 测试scss是否生效&#xff1a; styles/mian.scss :root{--mian:red; } App.vue <template><div>你好</div> </template><s…

红队打靶练习:EVM: 1

目录 信息收集 1、arp 2、netdiscover 3、nmap 4、nikto 5、whatweb 目录探测 1、gobuster 2、dirsearch WEB wpscan get username get password MSF get shell 提权 get root get flag 信息收集 1、arp ┌──(root㉿ru)-[~/kali] └─# arp-scan -l Interf…