news 2026/4/3 2:59:42

Django 用 Loguru 完美替换标准 Logging,实现优雅的日志管理方案

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Django 用 Loguru 完美替换标准 Logging,实现优雅的日志管理方案

Django 用 Loguru 完美替换标准 Logging,实现优雅的日志管理方案

这篇文章将详细拆解如何将强大的loguru库深度集成到 Django 项目中,彻底解决原生logging配置冗长、难以维护的痛点。


为什么要进行方案替换

Django 默认的日志配置通过LOGGING字典实现,嵌套层级多且语法繁琐。相比之下,loguru提供了更直观的 API 和自动化的日志轮转管理。

核心技术要点

  • 全量拦截:通过自定义InterceptHandler类,将 Django 内置、Gunicorn 容器以及第三方库产生的标准logging消息全部重定向至loguru

  • 精准溯源:利用sys._getframe动态查找调用栈,确保日志中显示的文件名和行号是真实的业务逻辑位置,而非拦截器本身。

  • 自动化策略:配置文件输出时,只需一行代码即可实现凌晨定时切割日志(rotation)和 30 天自动清理(retention)。

  • 并发安全:开启enqueue=True选项,利用多线程/进程安全的队列机制,防止高并发下日志写入冲突。

部署实践:一键接管 Django 日志

在项目中创建日志工具模块后,只需在settings.py顶部导入,并设置LOGGING_CONFIG = None即可禁用 Django 原生逻辑。

Python

import os import sys import logging from pathlib import Path from loguru import logger # 路径初始化 BASE_DIR = Path(__file__).resolve().parent.parent log_dir = os.path.join(BASE_DIR, "logs") log_file_path = os.path.join(log_dir, "dt_test.log") if not os.path.exists(log_dir): os.makedirs(log_dir) # 拦截器定义:核心在于深度(depth)的计算 class InterceptHandler(logging.Handler): def emit(self, record): try: level = logger.level(record.levelname).name except ValueError: level = record.levelno frame, depth = sys._getframe(6), 6 while frame and frame.f_code.co_filename == logging.__file__: frame = frame.f_back depth += 1 logger.opt(depth=depth, exception=record.exc_info).log(level, record.getMessage()) # 彻底接管配置 LOGGING_CONFIG = None def setup_loguru(debug_mode: bool = True): logger.remove() log_format = "{time:YYYY-MM-DD HH:mm:ss,SSS} | {level: <8} | {name} [{module}.{function}:{line}] | {message}" # 控制台调试输出 if debug_mode: logger.add(sys.stdout, level="DEBUG", format=log_format, enqueue=True) # 文件持久化配置:支持每天凌晨切割与压缩 logger.add( log_file_path, level="DEBUG", format=log_format, rotation="00:00", retention="30 days", encoding="utf-8", enqueue=True, compression="zip" ) # 重定向系统级日志 logging.basicConfig(handlers=[InterceptHandler()], level=0, force=True) for name in ["django", "django.server", "gunicorn.access", "gunicorn.error"]: _log = logging.getLogger(name) _log.handlers = [InterceptHandler()] _log.propagate = False setup_loguru()

放在settings.py顶部或者原来日志配置信息全部删除后的地方

效果

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/27 15:34:52

浏览器内核如何把 C++ 桌面能力注入到 JavaScript?

JS 能调用 window.desktop.openFile() —— 并不是 Web 突然变强了&#xff0c;而是浏览器内核在背后完成了一整套跨进程绑定体系。一、核心问题&#xff1a;JS 是怎么“看到” C 的&#xff1f;我们从最终现象开始&#xff1a;window.desktop.openFile("C:\\test.txt&quo…

作者头像 李华
网站建设 2026/3/31 2:11:41

Chrome Safe Browsing:浏览器安全背后的全局防护机制解析

在现代浏览器中&#xff0c;用户每天都会访问海量网站、下载各种文件、输入敏感信息&#xff0c;例如密码或支付信息。然而&#xff0c;网络环境中存在大量潜在威胁&#xff0c;包括钓鱼网站、恶意下载、恶意扩展以及未知漏洞。Chrome 浏览器为了保证用户的上网安全&#xff0c…

作者头像 李华
网站建设 2026/3/31 5:08:34

【Django毕设全套源码+文档】基于Python的毕业生去向反馈调查平台的设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/3/19 0:18:06

性价比高的太原文创伴手礼定制厂家

性价比高的太原文创伴手礼定制厂家引言在当今社会&#xff0c;文创产品越来越受到人们的喜爱。无论是作为企业礼品、会议纪念品还是旅游纪念品&#xff0c;高质量且具有创意的伴手礼不仅能够传递情感&#xff0c;还能提升品牌形象。太原作为历史文化名城&#xff0c;拥有丰富的…

作者头像 李华
网站建设 2026/3/29 7:36:56

全网最全9个一键生成论文工具,自考学生必备!

全网最全9个一键生成论文工具&#xff0c;自考学生必备&#xff01; 自考路上的得力助手&#xff0c;AI 工具如何助力论文写作 在自考学习的过程中&#xff0c;论文写作是许多学生面临的难点。随着人工智能技术的发展&#xff0c;越来越多的 AI 工具被应用于学术写作中&#…

作者头像 李华