内存泄漏排查记录

前提

进来项目现场又反馈某低代码项目存在越用越卡的问题,遂摸鱼排查一波,顺便复习 Memory使用方法。

Memory界面分析

memory是浏览器自带的内存排查工具,用来展示浏览器当前的内存快照。

存在三种使用快照获取方式:

1. Heap snapshot

获取当前js堆栈的瞬时内存快照。

  • Distance表示当前对象离js垃圾回收根对象的引用层级,挂载在window下的对象distance是1。
  • Shallow Size表示当前对象的自身大小(不包含内部引用的其它对象所占的内存)
  • Retained Size表示当前对象的总体大小(包括有引用关系的其他对象)

可以使用Comparison比较最近两个快照的内存差异

从图中的Delta中,可以清楚看到内存变化。

2. Allocation instrumentation on timeline

展示内存随着时间的变化轴线。

类似于火焰图,可以详细分析某个时间段内存变化

3. Allocation sampling

展示某个时间段内的内存变化。也就是方法二截取某个时间段的效果。该方法虽然没有方法2功能强,但是开销小,可以测试更长的时间区间。

只显示发生变化的内存快照,非常好用

如何定位内存泄漏

通过上面的快照,很快就能确定是否发生内存泄漏。之后该如何定位相关代码并解决问题呢?

1. 通过代码跳转链接

快照中存在产生该内存的相关代码链接,可以点击直接查看。

如果对项目代码熟悉的话,可以直接发现内存泄漏的相关代码。

2. 通过store as global variable功能

项目中代码往往比较复杂,并且经过编码压缩。通过代码链接点进去可能直接可能完全看不明白。这时候可以用下面的方法直接查看当前对象: store as global variable可以将当前对象存在window上并且直接输出:

这时候便可以查看对象,并且快速找到泄漏的部分:

例如该泄漏问题就是bus总线事件未及时处理导致的, 后续结合项目实际情况进行处理即可

相关推荐
持敬chijing5 分钟前
Web渗透之前后端漏洞-文件上传漏洞-过滤绕过与配置文件漏洞-条件竞争漏洞
前端·安全·web安全·网络安全·网络攻击模型·安全威胁分析
尼斯湖皮皮怪10 分钟前
iceCoder:验收门控深度分析
前端·agent
周庆猛12 分钟前
Babylon.js 多灯场景在 Windows 上报错:VERTEX shader uniform block count exceeds GL_MAX_VE
前端·数据可视化
胡志辉13 分钟前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·面试
槑有老呆19 分钟前
用 Bun 写一个 RESTful TodoList,顺便把面向接口编程整明白
前端
英勇无比的消炎药19 分钟前
别再盲目混用AI组件库和传统组件库差距原来这么大
前端·vue.js
ViavaCos19 分钟前
AI 帮我写代码,我帮 AI 踩坑:Vue 大数据表格优化全记录
前端·性能优化
lichenyang45338 分钟前
聊天消息的「状态」该怎么存?从一堆 boolean 到一个状态机
前端
gz-郭小敏44 分钟前
优化横向滚动展示大量数据的时候数据晃动问题
前端·javascript·html·css3
ClouGence1 小时前
自动化测试 CueCast 新版本发布:录制更稳、回放更准、排障更清晰
前端·程序员·测试