1.frr内存泄漏
修改frr代码后,运行过程中发现存在内存泄漏,使用valgrind进程定位。
2.使用Valgrind定位
使用valgrind启动bgpd:
bash
valgrind \
--leak-check=full \
--show-leak-kinds=all \
--track-origins=yes \
--log-file=/tmp/bgpd.valgrind \
--error-limit=no \
--fair-sched=try \
/usr/lib/frr/bgpd \
-F traditional \
-A 127.0.0.1 \
-f /etc/frr/frr.conf \
-l /logs/bgpd.log \
--log-level debug
运行一段时间,出现内存泄漏后,停止valgrind。分析/tmp/bgpd.valgrind报告。
3.解读 Valgrind 的输出
Valgrind 会将泄漏分为以下几种类型,重点关注前两类:
-
definitely lost:肯定泄漏,即程序分配了内存但没有释放,并且已经没有指针指向这块内存了 → 必须修复。
-
indirectly lost:间接泄漏,通常伴随 "definitely lost" 出现,修复了直接泄漏后,这部分往往会消失。
-
possibly lost:可能泄漏,即程序可能还有指针指向这块内存(比如移动了起始位置)。需要检查是否真的泄漏。
-
still reachable:程序结束时仍然可达的内存,通常是全局变量或静态缓存,一般情况下可以不算泄漏,但最好也检查一下。