返回首页  设为首页  加入收藏  今天是:
网站首页电脑主板电脑cpu电脑内存电脑硬盘电脑显卡电脑电源显示器电脑配件电脑维修
相关文章
 内存泄露?腾讯工程师2个压箱…
 Batch大小不一定是2的n次幂M…
 史上最小!USB 30+SATA 30!…
 中学语文老师干出一个IPO:三…
 英特尔Oak Trail 10寸铝壳平…
 在工控电脑内部安装独立显卡…
 电脑显卡安装的图文教程
 小而美的安卓性能机皇:一加…
 【双11专场】PUBG主机硬件选…
 B660可以装4060吗
 RTX 4060显卡性能怎么样 会像…
 4080显卡出了吗 显卡价格是多…
 晚间公告热点追踪:隆基股份…
 公告精选:多家公司前两月业…
 福建实达集团股份有限公司20…
 适合外出使用的笔记本电源SA…
 深市上市公司公告(10月22日…
 台式机硬盘是什么样的
 电脑磁盘和硬盘的区别
 三种电脑硬盘类型的区别与数…
 计算机主机干什么电脑硬盘是…
 【手慢无】老电脑升级神器!…
 广东省中医院CT设备维保服务…
 疫情叠加寒潮这群人24小时枕…
 天津海特:15亿“小目标”的…
 微软推出在线咨询电脑修复问…
 足不出户 360电脑专家为您免…
 做电商如何找货源?33个货源…
 五个做淘宝你必须收藏的货源…
 批批网打造服装批发直播新模…
 阿里巴巴批发网官方网(阿里…
 富农商网----农产品采购批发…
 遇圣诞购好礼华硕纯白显示器…
 千元预算的4K显示器KOIOSK27…
 2021年显示器怎么挑选?科普…
 MiniLED显示器线Q Max一步到…
 什么电竞显示器比较好 推荐三…
 中国笔记本CPU风扇市场分析及…
 Noctua推出被动式CPU散热器高…
 旧猫:5千价位笔记本电脑推荐…
 【装机科普日报】第22期:电…
 电竞笔记本电脑细分市场崛起…
 愉快买买买:DDR5内存价格看…
 影驰发布全球第三款8GHz DDR…
 百维存储688525上市估值分析…
 vivo S16系列发布:首创双面…
 vivo X90电池容量多大 最大内…
 40系显卡到来趁着双12优惠正…
 PC早报|苹果“xrOS”首曝美…
 电脑显卡接口类型 原创
专题栏目
网络
您现在的位置: 电脑评测网 >> 电脑内存 >> 正文
高级搜索
内存泄露?腾讯工程师2个压箱底的方法和工具
作者:佚名 文章来源:本站原创 点击数: 更新时间:2022/12/24 12:29:55 | 【字体:

  穿越成冷妃导读|遭受内存泄露往往是令开发者头疼的问题,传统分析工具 gdb、Valgrind在解决内存泄露问题上效率较低。本文特别邀请到了腾讯后台开发工程师邢孟棒以 TDSQL实际生产中mysql-proxy内存泄露问题作为分析对象,分享其基于动态追踪技术的通用内存泄露(增长)分析方法。其中将详细介绍内存分配器行为分析、缺页异常事件分析,涵盖应用程序内存分配的常见过程。阅读完本文后,开发者仅需关注少数可能导致内存泄露的代码路径,就能有效提升定位内存泄露(增长)问题的效率。

  某个 TDSQL 私有化环境中, 中间件 mysql-proxy 进行大量请求转发时,内存占用量持续增长导致 OOM 现象,最终影响了用户业务的正常使用 。本人分析该问题的过程中发现一个较为普遍的业务痛点:传统分析工具(gdb、Valgrind 等)效率相对较低,在私有化场景中尤其突出。针对这一痛点,我将提供相对通用的内存泄露(增长)分析方法,协助各位开发者更高效地定位发生泄露的代码路径,以期最大化减少人力投入成本并降低对用户业务体验的影响。

  内存泄露包括内核内存泄露、应用程序内存泄露两大类。内核内存泄露可以通过 kmemleak 进行检测,本文主要关注应用程序的内存泄露。应用程序的内存泄露又可以细分为:堆内存(Heap)泄露、内存映射区(Memory Mappings)泄露。我们平时提及的内存泄露,主要是指物理内存的泄露(持续分配、映射实际的物理内存,且一直未释放),危害较大,需要立即修复。

  另外,虚拟内存的泄露(持续分配虚拟内存,但未分配、映射实际的物理内存)容易被忽视,虽然危害相对较小,但也需额外关注(进程的内存映射区总数量有上限,默认 1w)。

  第一,应用程序通过内存分配器(例如 libc)提供的 malloc 及其变体函数申请内存,free 函数释放相应内存。第二,内存分配器(例如 libc)内部通过系统调用 brk 扩展堆内存(小块内存分配)。第三,内存分配器(例如 libc)内部通过系统调用 mmap 分配内存映射区域(大块内存分配,默认不小于 128 KB)第四,二或三已申请的虚拟内存在首次写入时触发缺页异常,OS 分配实际物理页面,并将虚拟内存与其相关联,记录至页表。

  在定位 mysql-proxy 内存泄露(增长)问题的过程中,开发人员尝试使用了 Valgrind Memcheck、gdb 进行协助分析。最终前者实际效果不太理想;我通过后者分析出泄露原因,但整个过程耗费了较多时间。

  gdb 是常用的程序调试工具,好处不用赘述。但对于内存泄露或增长问题,gdb 缺点也较为明显,大致如下:干扰程序正常运行,不适合生产环境;直接定位比较困难,且要求对源码有一定了解。

  Valgrind Memcheck 是一款知名度较高的内存泄露分析工具,非常强大,开发调试过程中能够快速发现场景的内存泄露问题。不过开发者在使用之前,建议对以下情况有所了解:

  第一,需要重启程序,且作为 Valgrind 子进程运行。不适合分析正在发生内存增长的进程。

  第二,替代默认的 malloc/free 等分配函数,目标进程运行速度减慢 20~30 倍。

  对于正在运行、内存持续增长的应用来说,gdb、Valgrind Memcheck 工具其实都挺难发挥价值。相比而言,动态追踪技术提供了一种通用且易用的方式。内存分配器相关函数调用、系统调用、缺页异常等,都可以看作一个个事件。通过对这些事件的追踪、统计等,我们可以分析有关内存使用情况的具体代码路径,在不深入源码细节的前提下快速缩小泄露发生的范围。

  本文涉及两种基于动态追踪的通用分析方法:内存分配器行为分析、缺页异常事件分析,涵盖应用程序内存分配的常见过程。

  其次,动态追踪内存分配相关函数,统计未释放内存分配的调用栈与总字节数量,形成分析工具 memstacks。

  一种是仅追踪 malloc 及其变体函数,不做 free 抵消,结果可用于生成全量内存分配火焰图。

  另一种是追踪 malloc 及其变体函数、free 函数,计算出追踪期间未释放的内存分配,结果可用于生成未释放内存分配火焰图。

  借鉴现有 BCC 工具 memleak、mallocstacks,支持生成折叠栈,可生成全量内存分配火焰图、未释放内存分配火焰图。

  如上图所示,现有 BCC 工具 memleak、mallocstacks 各有优劣。新工具 memstacks 结合两者优点,允许有选择性的生成全量内存分配火焰图或者未释放内存分配火焰图需要的折叠栈格式。

  执行以下命令,追踪 mysql-proxy 进程所有 malloc 及其变体调用 60s,并生成全量内存分配火焰图。

  火焰图如下所示,可以协助开发者理解 mysql-proxy 调用 malloc 及其变体的关键代码路径。

  执行以下命令,追踪 mysql-proxy 进程未释放 malloc 及其变体调用 60s,并生成内存分配火焰图。

  已分配但未释放的代码路径主要有两处。其中,据研发反馈,tdsql::Item_param::set_str 正是导致 mysql-proxy 内存泄露发生的地方。而另一处并非真正的泄露。该工具有一定的副作用,由于追踪的最后阶段有一些刚分配的内存还未来得及释放,需要进一步阅读源码甄别。另外,建议多运行几次对比下结果,排除那些经常变化的分配路径。

  相比全量内存分配火焰图,数据量减少近 60 倍,需要重点关注的代码路径的减少也比较明显。因此,推荐优先使用未释放内存分配火焰图进行分析。

  相比内存分配器行为分析,缺页异常事件分析提供了另一种视角,整体思路如下:

  首先,站在内核视角,关注的是首次写入触发缺页异常的代码路径,而不是触发内存分配的代码路径。前者是进程 RSS增长的原因,后者仅分配了虚拟内存,尚未映射物理内存。

  其次,追踪缺页异常事件,统计未释放物理内存的调用栈与总页面数量,形成分析工具 pgfaultstacks。

  现有分析工具虽然方便,但是以增量的方式去统计,不考虑追踪过程中被释放的物理内存,最终统计的结果通常会偏大,对内存泄露(增长)的分析会造成干扰。

  执行以下命令,追踪 mysql-proxy 进程所有缺页事件 60s,并生成缺页异常火焰图。

  火焰图具体如下,共计 420,342 次缺页事件,但不是每一次缺页事件都分配一个新的物理页面(大多数情况下未分配),mysql-proxy RSS 实际增长量仅 60 多MB 。

  第一,改进现有缺页事件统计方式(过滤物理页面已存在的缺页事件,并在追踪完成后读取目标进程的内存映射列表,通过计算将已释放的物理页面排除在外),仅关注真正泄露的物理内存。

  执行以下命令,追踪 mysql-proxy 进程满足过滤条件的缺页事件 60s,并生成缺页火焰图。

  重点关注函数 g_string_append_printf。(注:非内存泄露发生的环境,仅用来演示缺页异常火焰图)

  相比现有版,该版本的数据量减少 20 多倍,需要重点关注的代码路径减少也比较明显。

  本文以 TDSQL 实际生产中 mysql-proxy 内存泄露问题作为分析对象,探索基于动态追踪技术的通用内存泄露(增长)分析方法:内存分配器行为分析、缺页异常事件分析,并针对现有分析工具进行改进,形成相应的分析工具 memstacks、pgfaultstacks,欢迎各位开发者尝试去开发。工具使用者仅需关注少数可能导致内存泄露的代码路径,有效提升定位内存泄露(增长)问题的效率。如果你正在遭受内存泄露(增加)的困扰,不妨尝试下本文提及的分析方法和工具,希望有所帮助。

电脑内存录入:admin    责任编辑:admin 
  • 上一个电脑内存:

  • 下一个电脑内存: 没有了
  •  
     栏目文章
    普通电脑内存 内存泄露?腾讯工程师2个压箱底的方法和工具 (12-24)
    普通电脑内存 Batch大小不一定是2的n次幂ML资深学者最新结论 (12-24)
    普通电脑内存 愉快买买买:DDR5内存价格看齐DDR4了! (12-24)
    普通电脑内存 影驰发布全球第三款8GHz DDR5内存:如此光污染… (12-24)
    普通电脑内存 百维存储688525上市估值分析和申购建议 (12-24)
    普通电脑内存 vivo S16系列发布:首创双面柔光人像 搭载内存… (12-24)
    普通电脑内存 vivo X90电池容量多大 最大内存是多少? (12-24)
    普通电脑内存 图文细说计算机存储器的历史 (12-23)
    普通电脑内存 考研计算机专业基础综合试题 (12-23)
    普通电脑内存 计算机系统的组成与功能 (12-23)
    普通电脑内存 计算机基础知识试题及答案 (12-23)
    普通电脑内存 SK海力士公布DDR5内存规范这个时序我顶不住了… (12-23)
    普通电脑内存 手机里垃圾太多找到手机这个设置彻底清除垃圾… (12-23)
    普通电脑内存 小技巧:如何为iOS设备腾出更多存储空间 (12-23)
    普通电脑内存 JTG 6310-2022英文版 收费公路联网收费技术标… (12-23)
    普通电脑内存 东京奥运口号只有英文版引争议:中文译本五花… (12-23)
    普通电脑内存 “内存刺客”微信键盘初体验:不得不说是个整… (12-23)
    普通电脑内存 西数-电子发烧友网 (12-23)
    普通电脑内存 硬件常用的英文缩写 (12-23)
    普通电脑内存 内存中的随机存储器的英文缩写为 (12-23)