ZoneMinder内存泄漏问题分析与修复
2025-06-07 09:32:34作者:袁立春Spencer
问题背景
ZoneMinder作为一款开源的视频监控系统,在1.37.50版本中出现了zmc进程内存泄漏的问题。该问题表现为监控进程会缓慢消耗系统内存,最终可能导致系统资源耗尽。问题最初在Ubuntu Jammy系统上被发现,影响使用FFMPEG源类型的监控摄像头。
问题现象
受影响的环境具有以下特征:
- 监控配置为使用子码流(640x360或720x576分辨率)
- 帧率为15FPS
- 最大图像缓冲区设置为1000-3000帧
- 关键帧间隔为29
- 分析功能关闭(Analysis=None)
- 解码功能关闭(Decoding=None)
- 录制模式为"Always"并使用摄像头直通
系统日志中会反复出现警告信息:"You have set the max video packets in the queue to 3000. The queue is full. Either Analysis is not keeping up or your camera's keyframe interval 29 is larger than this setting."
问题分析
通过深入分析,发现问题根源在于分析线程与视频包队列的交互机制。即使分析功能被关闭(设置为None),分析线程仍然会尝试从视频包队列中获取数据包。当解码功能也关闭时(Decoding=None),分析线程会持续等待一定数量的帧被解码,但实际上这些帧永远不会被解码,导致线程陷入等待状态。
这种等待状态导致视频包队列不断积累而无法被及时消费,最终造成内存泄漏。系统日志中的警告信息准确地反映了这一状况 - 视频包队列已满,但分析线程无法及时处理。
技术细节
在ZoneMinder的架构中:
- 视频捕获线程持续从摄像头获取视频数据包并放入队列
- 分析线程负责从队列中取出数据包进行处理
- 当解码功能关闭时,分析线程会等待"ready_count"(默认为75)数量的帧被解码
- 由于解码功能关闭,这个条件永远不会满足,导致分析线程持续休眠
- 视频包队列因此不断增长,消耗大量内存
解决方案
ZoneMinder开发团队迅速响应并修复了这一问题。修复的核心思路是:
- 当解码功能关闭时,不再要求分析线程等待解码帧
- 确保分析线程能够正确处理不进行解码的情况
- 优化视频包队列的管理机制
验证结果
修复后经过数小时测试:
- 系统内存使用稳定在5GB左右
- 不再出现内存持续增长的现象
- 视频包队列保持正常水平
- 系统警告信息不再出现
最佳实践建议
对于ZoneMinder用户,建议:
- 及时更新到包含此修复的最新版本
- 监控系统日志中的队列警告信息
- 根据实际需求合理设置最大图像缓冲区大小
- 对于仅需录制不需要分析的摄像头,可以放心使用"Analysis=None"和"Decoding=None"配置
此问题的修复体现了ZoneMinder团队对系统稳定性的持续关注,也展示了开源社区快速响应和解决问题的能力。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0215
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
465
暂无描述
Dockerfile
779
5.08 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
876
2.03 K
Ascend Extension for PyTorch
Python
758
968
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
697
1.4 K
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.25 K
677