0

0

Python日志轮转机制_长期运行说明【指导】

舞姬之光

舞姬之光

发布时间:2026-01-01 19:21:10

|

416人浏览过

|

来源于php中文网

原创

python日志轮转需显式配置rotatingfilehandler(按大小)或timedrotatingfilehandler(按时间),注意多进程、重启残留、外部logrotate冲突及平台兼容性,推荐按天轮转+压缩+分级日志+清理钩子。

python日志轮转机制_长期运行说明【指导】

Python日志轮转(Log Rotation)是保障长期运行服务日志可控、不占满磁盘的关键机制。默认的 FileHandler 不会自动切分或清理旧日志,必须显式配置轮转策略,否则可能因日志无限制增长导致服务异常或系统告警。

使用 RotatingFileHandler 控制单文件大小

适用于按体积轮转的场景,比如单个日志文件不超过 10MB,最多保留 5 个历史文件:

  • 导入 logging.handlers.RotatingFileHandler
  • 设置 maxBytes=10*1024*1024(即 10MB)
  • 设置 backupCount=5,超出时自动删除最老的 .1、.2… 文件
  • 注意:轮转只在写入时触发,不会主动扫描清理;文件名后缀为 .1.2 等,原日志始终是无后缀的主文件

使用 TimedRotatingFileHandler 按时间切分

适合需按天/小时归档的运维习惯,例如每天生成一个新日志文件:

  • 指定 when='midnight'(每日零点)、'D'(同义)、'H'(每小时)、'W0'(每周一)等
  • interval=1 配合 when,避免误设成每秒轮转
  • backupCount=30 表示最多保留最近 30 个周期的日志(如 30 天)
  • 生成的文件名含时间戳,如 app.log.2024-05-20,依赖系统时区;建议统一设为 UTC 或显式指定 utc=True

避免常见陷阱

长期运行中容易忽略但影响严重的细节:

九歌
九歌

九歌--人工智能诗歌写作系统

下载

立即学习Python免费学习笔记(深入)”;

  • 多进程共用同一日志文件时,RotatingFileHandler 无法保证原子性,可能导致日志错乱或丢失 —— 应改用 QueueHandler + QueueListener 或集中式日志方案
  • 程序重启后,若未重新初始化 logger,旧 handler 可能残留,造成重复写入或轮转失效
  • Linux 下被 logrotate 外部轮转后,Python 进程仍持有原文件句柄,新日志会继续写入已被重命名的旧文件 —— 需配合 logging.handlers.BaseRotatingHandler.doRollover() 或监听信号重开文件
  • Windows 上对正在写的日志文件重命名可能失败,TimedRotatingFileHandler 默认使用 os.rename,建议测试兼容性或改用 delay=True 缓解

生产环境推荐组合

兼顾可读性、排查效率与磁盘安全:

  • 按天轮转 + 压缩归档:用 TimedRotatingFileHandler 配合自定义 doRollover 方法,在切分后调用 gzip 压缩旧文件
  • 主日志 + 错误专项日志:INFO 级别写入 daily 日志,ERROR 单独进 error.log 并启用大小轮转,便于快速定位异常
  • 添加日志清理钩子:在应用退出前调用 handler.close(),避免最后几条日志未刷盘
  • 定期校验:脚本检查 log/ 目录下文件总数和总大小,超限时触发告警而非静默丢弃

日志轮转不是“配完就完”的一次性动作,而是需要结合部署方式、运行周期和运维习惯持续验证的环节。一次合理配置,能省去后期大量磁盘排查和人工清理工作。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

431

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

373

2023.10.25

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1408

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1160

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

832

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

461

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2361

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

874

2023.08.10

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.2万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号