Python多进程日志记录技巧
时间:2026-01-26 23:08:37 477浏览 收藏
小伙伴们有没有觉得学习文章很有意思?有意思就对了!今天就给大家带来《Python多进程日志记录正确方法》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
Python多进程日志需子进程独立配置,推荐用QueueHandler+QueueListener实现主进程集中写入,避免文件竞争;调试时可用带pid的文件名或StreamHandler。

在 Python 的 multiprocessing 中,子进程默认不继承主进程的 logging 配置,直接使用 logging.info() 等可能无输出、报错,甚至导致进程卡死。关键在于:每个进程需独立配置 logger,且避免多个进程同时写入同一文件引发竞争或损坏。
为每个子进程单独初始化 logging
子进程中不能依赖主进程的 logger 配置。应在子进程函数开头主动调用 logging.basicConfig() 或获取 root logger 后添加 handler:
- 推荐方式:在子进程入口函数(如
worker())第一行配置 logging,确保每次启动都干净初始化 - 避免在模块顶层或
if __name__ == '__main__':外配置 —— 子进程会重新执行模块,但此时basicConfig()可能因已存在 handler 而静默失败 - 若用
logging.getLogger(),记得清除已有 handler:logger.handlers.clear(),再添加新 handler
避免多进程写同一个日志文件
多个子进程直接往同一个文件 FileHandler 写日志,会导致内容错乱、丢失甚至文件损坏。可行方案有:
- 给每个进程的日志文件加唯一后缀,例如用
os.getpid()或current_process().pid:FileHandler(f'app_{os.getpid()}.log') - 统一由主进程接收日志消息(通过
QueueHandler+QueueListener),实现集中写入 —— 这是最健壮的生产级方案 - 临时调试可用
StreamHandler(sys.stderr),输出到控制台(注意 Windows 下可能仍需设置sys.stderr.reconfigure()或避免编码问题)
使用 QueueHandler 实现安全集中日志
这是官方推荐的多进程日志最佳实践:子进程只发日志消息,主进程专用线程监听并写入文件。
- 主进程创建
multiprocessing.Queue()和QueueListener,传入 file handler 并启动监听 - 子进程获取 logger,移除默认 handler,添加
QueueHandler(queue) - 注意:
QueueListener必须在if __name__ == '__main__':块中启动,且不能在子进程中重复创建 - 示例关键代码:
listener = QueueListener(queue, FileHandler('all.log'));listener.start();子进程里logger.addHandler(QueueHandler(queue))
其他实用细节
有些小问题容易踩坑,提前注意可省去大量调试时间:
- Windows 下 spawn 方式启动子进程时,模块会重新导入 —— 所有 logging 配置逻辑必须放在函数内,不要放模块全局作用域
- 使用
concurrent.futures.ProcessPoolExecutor时同样适用上述规则,子任务函数内需自行初始化 logging - 若用
RotatingFileHandler,多个进程无法安全共用,必须配合 Queue 或按进程分文件 - 日志格式建议包含进程 ID:
%(process)d或%(processName)s,便于区分来源
今天关于《Python多进程日志记录技巧》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
193 收藏
-
411 收藏
-
254 收藏
-
332 收藏
-
458 收藏
-
450 收藏
-
384 收藏
-
311 收藏
-
198 收藏
-
176 收藏
-
442 收藏
-
386 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习