新手教学系列——利用 Loguru 对日志进行分类处理

2024-08-23 20:52

本文主要是介绍新手教学系列——利用 Loguru 对日志进行分类处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在现代应用程序中,日志记录是确保系统健康运行的关键因素之一。尤其在复杂的系统中,我们可能需要将日志按不同的需求进行分类和处理。Loguru 作为一款功能强大的日志库,提供了灵活的日志记录方式。今天,我们将探讨如何使用 Loguru 的过滤功能来分类处理系统日志和关键节点日志,以满足特定需求。

需求场景

假设我们有两个主要的日志需求: 1. 标准系统日志:记录系统的常规信息,如运行状态和普通操作。 2. 关键节点日志:在系统的关键节点记录 Elasticsearch 相关的日志,以便进行详细分析和追踪。

配置 Loguru 记录系统日志和 Elasticsearch 日志

在使用 Loguru 之前,我们需要先进行基础配置,确保日志记录的准确性和有效性。下面的配置代码展示了如何设置不同的日志处理方式:

# 移除默认的日志处理器
logger.remove()# 配置标准系统日志处理器
logger.add(sys.stderr,  # 将日志输出到标准错误流level=env.str('LOGGER_LEVEL', 'INFO'),  # 日志级别,通过环境变量设置,默认为 INFOformat=env.str('LOGURU_FORMAT', DEFAULT_LOG_FORMAT),  # 日志格式,通过环境变量设置,使用默认格式backtrace=env.bool('LOGURU_BACKTRACE', True),  # 是否启用堆栈回溯diagnose=env.bool('LOGURU_DIAGNOSE', True),  # 是否启用诊断信息filter=lambda record: record["extra"].get("write_tag") is None,  # 过滤器:只记录没有 write_tag 的日志
)# 配置 Elasticsearch 日志处理器
logger.add(os.path.join(LOGS_PATH, 'task.log'),  # 将日志输出到指定的文件level=env.str('ES_LOG_LEVEL', 'INFO'),  # Elasticsearch 日志级别,通过环境变量设置,默认为 INFOrotation=env.str('TASK_LOG_ROTATION', '500 MB'),  # 日志文件轮换策略,达到 500 MB 后轮换format='{message}',  # Elasticsearch 日志格式,只记录消息部分filter=lambda record: record["extra"].get("write_tag") == 'elasticsearch',  # 过滤器:只记录 write_tag 为 'elasticsearch' 的日志
)# 配置异常处理选项
logger.opt(exception=True)

如何使用 Loguru 进行日志记录

在实际使用中,我们可以通过绑定 write_tag 来区分日志的目标。例如,若我们要记录 Elasticsearch 相关日志,可以这样进行配置:

# 绑定 write_tag,并记录 Elasticsearch 日志
logger.bind(write_tag="elasticsearch").info(orjson.dumps(es_log).decode('utf-8'))

便利性

Loguru 的设计旨在提供一种简单且无感的日志记录方式。通过直接从 loguru 模块导入 logger 对象,我们可以很方便地在代码中记录各种日志信息,而无需复杂的配置。通过 write_tag,我们能够标记日志的目标,使得日志的处理更加高效和精准。

总结

使用 Loguru 进行日志分类处理不仅能够提高系统的可维护性,还能帮助我们在关键节点进行有效的监控和分析。通过合理配置日志处理器和过滤器,我们可以确保系统日志和关键节点日志的准确记录,从而更好地理解和优化系统的运行状态。

关注【程序员的开发手册】,让您少走弯路,掌握更多开发技巧和实践经验。

这篇关于新手教学系列——利用 Loguru 对日志进行分类处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

我在移动打工的日志

客户:给我搞一下录音 我:不会。不在服务范围。 客户:是不想吧 我:笑嘻嘻(气笑) 客户:小姑娘明明会,却欺负老人 我:笑嘻嘻 客户:那我交话费 我:手机号 客户:给我搞录音 我:不会。不懂。没搞过。 客户:那我交话费 我:手机号。这是电信的啊!!我这是中国移动!! 客户:我不管,我要充话费,充话费是你们的 我:可是这是移动!!中国移动!! 客户:我这是手机号 我:那又如何,这是移动!你是电信!!