Python logging模块实现日志饶接 按照时间命名

import os
import zipfile
from datetime import datetime
from logging.handlers import RotatingFileHandlerclass CompressedRotatingFileHandler(RotatingFileHandler):"""自定义的 RotatingFileHandler,支持在日志轮转时压缩旧日志文件,并管理压缩文件的最大数量。"""def __init__(self, filename, mode='a', maxBytes=10 * 1024 * 1024, backupCount=5, encoding=None, delay=False):"""初始化处理器。:param filename: 日志文件名。:param mode: 打开文件的模式,默认是追加模式 'a'。:param maxBytes: 日志文件的最大字节数,达到后进行轮转。:param backupCount: 保留的压缩日志文件的最大数量。:param encoding: 文件编码。:param delay: 如果为 True,则文件将在第一次写入时打开。"""super().__init__(filename, mode, maxBytes, backupCount, encoding, delay)self.backupCount = backupCountdef doRollover(self):"""执行日志轮转:关闭当前日志文件,重命名并压缩旧日志文件,然后删除多余的压缩日志文件。"""if self.stream:self.stream.close()self.stream = None# 获取当前时间戳timestamp = datetime.now().strftime("%Y-%m-%d-%H-%M-%S")# 定义压缩后的文件名zip_filename = f"{os.path.splitext(self.baseFilename)[0]}_{timestamp}"file_name = os.path.basename(zip_filename)# 创建 zip 压缩包并添加日志文件with zipfile.ZipFile(zip_filename + '.zip', 'w', zipfile.ZIP_DEFLATED) as zipf:zipf.write(self.baseFilename, arcname=file_name + '.log')# 清空当前日志文件with open(self.baseFilename, 'w'):pass# 管理备份文件self._cleanup_old_logs()def _cleanup_old_logs(self):"""删除多余的压缩日志文件,保留最新的 backupCount 个文件。"""dir_name, base_name = os.path.split(self.baseFilename)prefix = os.path.splitext(base_name)[0] + "_"suffix = ".zip"# 获取所有符合命名规则的压缩日志文件compressed_files = [os.path.join(dir_name, f) for f in os.listdir(dir_name)if f.startswith(prefix) and f.endswith(suffix)]# 按修改时间排序,最新的在后面compressed_files.sort(key=lambda x: os.path.getmtime(x))# 删除多余的文件while len(compressed_files) > self.backupCount:oldest = compressed_files.pop(0)os.remove(oldest)import loggingdef setup_logger(log_file, max_bytes=10 * 1024 * 1024, backup_count=5, log_level=logging.INFO):"""配置并返回一个日志记录器。:param log_file: 日志文件路径。:param max_bytes: 日志文件的最大字节数,超过后进行轮转和压缩。:param backup_count: 保留的压缩日志文件的最大数量。:param log_level: 日志级别。:return: 配置好的 Logger 对象。"""logger = logging.getLogger("CompressedLogger")logger.setLevel(log_level)logger.propagate = False  # 防止日志传递到根记录器if not logger.handlers:handler = CompressedRotatingFileHandler(filename=log_file,maxBytes=max_bytes,backupCount=backup_count,encoding='utf-8')formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')handler.setFormatter(formatter)logger.addHandler(handler)return logger# 使用示例
if __name__ == "__main__":logger = setup_logger("logs/application.log", max_bytes=0.5 * 1024 * 1024, backup_count=2000,log_level=logging.DEBUG)for i in range(100000):logger.info(f"这是第 {i} 条日志记录")

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

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

相关文章

【算法】深入理解布隆过滤器

1. 什么是布隆过滤器? 布隆过滤器(Bloom Filter)是一种空间效率极高的概率型数据结构,用于检测某个元素是否在一个集合中。与常见的数据结构如哈希表不同,布隆过滤器无法删除元素,并且会存在一定的误判率&…

用示波器观测RC一阶电路零输入响应是否激励必须是方波信号

概述 RC一阶电路是一种简单但非常重要的电路,广泛应用于滤波、信号处理和时间常数分析等领域。在研究RC电路的动态特性时,零输入响应(Natural Response)是一项关键内容。本文将详细解析用示波器观测RC一阶电路零输入响应时&#…

开发语言最佳实践

目录 一、开发IOS最好的语言是什么? 二、开发安卓的最好语言是什么? 三、开发鸿蒙应用最好的语言是什么? 四、做大模型训练最好的开发语言是什么? 一、开发IOS最好的语言是什么? 开发iOS最好的语言是Swift。Swift…

C#学习笔记(六)

C#学习笔记(六) 第 三 章 基本语句以及语法二、程序逻辑 if 选择和分支结构 switch1. if2. switch 三、循环语句1. for 循环的使用2. while 循环的使用3. 对比 break 和 continue 第 四 章 字符串 string 详解和高效 StringBuilder 类暂不练习与学习。 第…

CAD快捷键大全非常详细

绘图菜单 快捷键 注意事项 1.线 L 2.构造线 XL 3.多段线 PL 一般用来画三维图 4.正多边形 POL 5.矩形 REC 6.圆弧 A 7.圆 C 8.修订云线 REVCLOUD 9.样条曲线 SPL 10.椭圆 EL 轴测图:ELI 11.椭圆弧…

如何实现安川MP3300运动控制器与西门子1200系列PLC进行ModbusTCP通讯

在工业自动化中,实现不同品牌、不同型号设备之间的通讯是确保生产流程顺畅、高效运行的关键。本文详细介绍了安川MP3300运动控制器与西门子1200系列PLC进行ModbusTCP通讯的具体方法。 一.软硬件需求 1.一台安川MP3300CPU301,其IP地址是192.…

SpringCloudAlibaba升级手册

目录 1. 版本对照 版本现状 SpringCloud与AlibabaCloud对应版本 Springboot与Elasticsearch版本对应 2. openfeign问题 问题 解决方案 3. Feign请求问题 问题 解决方法 4. Sentinel循环依赖 问题 解决方案 5. bootstrap配置文件不生效 问题 解决方案 6. Nacos的…

Codeforces Round 929 (Div. 3) F. Turtle Mission: Robot and the Earthquake

题目 题解&#xff1a; 按题解思路的代码&#xff1a; #include <bits/stdc.h>using i64 long long;void solve() {int n, m;std::cin >> n >> m;std::vector a(n, std::vector<int>(m));for (int i 0; i < n; i) {for (int j 0; j < m; j) …

STM32—SPI通讯协议

前言 由于I2C开漏外加上拉电阻的电路结构&#xff0c;使得通信线高电平的驱动能力比较弱&#xff0c;这就会号致&#xff0c;通信线由候电平变到高电平的时候&#xff0c;这个上升沿耗时比较长&#xff0c;这会限制I2C的最大通信速度&#xff0c; 所以&#xff0c;I2C的标准模…

uniapp-小程序开发0-1笔记大全

uniapp官网&#xff1a; https://uniapp.dcloud.net.cn/tutorial/syntax-js.html uniapp插件市场&#xff1a; https://ext.dcloud.net.cn/ uviewui类库&#xff1a; https://www.uviewui.com/ 柱状、扇形、仪表盘库&#xff1a; https://www.ucharts.cn/v2/#/ CSS样式&…

经纬恒润荣获2024中国汽车供应链大会创新成果奖

2024年9月24日-26日&#xff0c;2024中国汽车供应链大会暨第三届中国新能源智能网联汽车生态大会在武汉隆重举办。本届大会以“新挑战、新对策、新机遇——推动中国汽车供应链可持续发展”为主题&#xff0c;集聚政府主管领导、行业专家、汽车及零部件企业精英和主流媒体&#…

Ubuntu24.04 安装 NCAR Command Language(NCL)

目录 一般直接在Terminal中使用apt安装命令即可&#xff0c; 出现这样的问题&#xff0c; 如何解决这个问题呢&#xff1f; 一般直接在Terminal中使用apt安装命令即可&#xff0c; sudo apt install ncl-ncarg 但是&#xff0c;由于 Ubuntu 版本较新 Ubuntu 24.04&#xff…

Application protocol

### 11 应用协议 #### 11.1 通用程序 - 涉及不同类型文件的程序应遵循3GPP TS 31.101 [55]的规定&#xff0c;但不支持使用短文件ID。 #### 11.2 SIM管理程序 - 包括SIM初始化、GSM会话终止、紧急呼叫代码请求、语言偏好请求、行政信息请求、SIM阶段请求等。 - SIM初始化包括…

Python OpenCV精讲系列 - 三维重建深入理解(十七)

&#x1f496;&#x1f496;⚡️⚡️专栏&#xff1a;Python OpenCV精讲⚡️⚡️&#x1f496;&#x1f496; 本专栏聚焦于Python结合OpenCV库进行计算机视觉开发的专业教程。通过系统化的课程设计&#xff0c;从基础概念入手&#xff0c;逐步深入到图像处理、特征检测、物体识…

迪杰斯特拉算法的理解

图片转载自&#xff1a;最短路径算法-迪杰斯特拉(Dijkstra)算法 - 程序小哥爱读书的文章 - 知乎 https://zhuanlan.zhihu.com/p/346558578 迪杰斯特拉&#xff0c;一个广度优先算法&#xff0c;采用了贪心策略。 第一步&#xff0c;选取顶点D&#xff0c;更新和D相连的节点C&a…

78天闭门深造1258页SpringCloud学习进阶笔记,再战蚂蚁金服

概述 作为一名程序员应该都知道SpringCloud&#xff0c;不知道就该反思一下了啊[奸笑]。所以就不有板有眼的和官方的介绍一样了&#xff0c;今天就说一下&#xff0c;我理解的SpringCloud是什么&#xff1a;我所理解的Spring Cloud就是微服务系统架构的一站式解决方案&#xf…

Java项目: 基于SpringBoot+mysql+maven+vue林业产品推荐系统(含源码+数据库+毕业论文)

一、项目简介 本项目是一套基于SpringBootmybatismavenvue林业产品推荐系统 包含&#xff1a;项目源码、数据库脚本等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#xff0c;eclipse或者idea 确保可以运行&#xff01; 该系统功能完善、界面美观、操…

Python-计算三角形面积的方法

&#xff03;Python创建用于计算的属性 &#xff03;定义一个三角形类&#xff0c;在__init__&#xff08;&#xff09;方法中定义实例属性. &#xff03;定义一个计算三角形面积的方法&#xff0c;并应用&#xff20;property将其转换为属性&#xff0c;最后创建类的实例&am…

算法工程师重生之第二十七天(合并区间 单调递增的数字 监控二叉树 总结)

参考文献 代码随想录 一、合并区间 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。 示例 1&#xff1a…

数据压缩(4)——字典编码

【前言】 变长编码&#xff0c;统计压缩编码都是基于单个字符的编码&#xff0c;字典编码基于数个连续字符&#xff08;也叫基于单词&#xff09;&#xff0c;例如ABCABD中AB可以替换成一个新的字符&#xff0c;其可能会减少字符数量&#xff0c;得到的新数据的熵比原来的小&a…