问题
常见的内存泄漏分析器,如: tcmalloc heap-profiler 、 valgrind 、 asan 、 bcc/memleak 等,要么比较重、要么需要 -O0 ,没法在线上使用
而线上的内存泄漏问题,没有分析工具,会造成排查问题困难
举个例子,笔者就遇到 1 个线上内存泄漏
问题:
- 30 分钟内,服务内存按固定斜率到 100% ,再几分钟后,直线回落到 30 分钟前水平
- 查看主机监控: CPU 、 流量 、 磁盘IO 、 socket 连接状态等等,均无异常
- 服务内置埋点指标:在线人数、房间数、待处理消息数等等,均无异常
因为没有合适的工具,导致排查问题,没有方向
因此需要一种方法,来提供内存分配的信息
malloc/free hook
要收集内存分配,需要有方法 hook malloc/free 方法
每个内存库,都有自己的 hook 接口/方法
笔者使用的是 tcmalloc ,这里介绍下 tcmalloc 的 hook 方法