BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

V8引擎内存消耗的分析和优化

| 作者 Sergio De Simone 关注 12 他的粉丝 ,译者 薛命灯 关注 23 他的粉丝 发布于 2016年10月18日. 估计阅读时间: 3 分钟 | GMTC大前端的下一站,PWA、Web框架、Node等最新最热的大前端话题邀你一起共同探讨。

在过去的几个月,V8团队一直致力于降低V8引擎内存消耗的工作,主要内容包括推出新的Ignition解释器以及对V8解析器和编译器的改进。来自V8的工程师Ulan Degenbaev、Michael Lippautz、Hannes Payer和Toon Verwaest说明了这次工作的主要目标之一是根据测试基准使用特别的工具对V8的内存使用情况进行分析。

为了减少V8的内存占用,V8团队利用Chrome 54版本的新特性对V8引擎的两个堆内存进行监控(C++堆和JavaScript堆)。Chrome的这个新特性提供了--trace--gc-object-stats标记,使用这个标记可以把V8的内存统计信息输出到控制台,然后使用V8 heap visualizer这个自制工具对输出的信息进行可视化,它会把两个堆的时间线视图以及对特定数据类型内存使用情况的详细分析结果展示出来。V8团队还使用Chrome提供的另一个工具Trace Event Profiling Tool来分析内存,这个工具可以通过about:tracing来启动。

内存分析的结果告诉我们,垃圾回收器的延迟和内存消耗之间的平衡是决定JavaScript堆内存大小的因素之一。为堆保留更多的内存可以避免频繁的GC,从而减少延迟。不过这对于低内存的设备来说会是个问题,它会导致设备崩溃或让应用程序挂起。为了达到延迟和内存消耗之间的平衡,V8团队引入了一种新的内存缩减模式,这个模式会触发更频繁的垃圾回收,并通过更有效的压缩来减少内存碎片。从一个测试基准可以看到,新的模式总共可以把V8堆内存缩减50%。引入的另一个优化措施是把V8的堆页面大小从1M减到512K,有助于改善整体内存使用以及减少内存碎片。

V8团队通过改进后台的解析任务来减小C++的堆内存,这种改进可以让V8在网页加载过程中解析脚本。实际上,就像内存可视化工具所展示的那样,后台解析器会在代码编译后的很长一段时间内仍然保留着一块活跃的堆区域,而不是马上把它释放掉。另外,V8解析器现在使用一种更有效的策略来压缩保存在语法树节点里的字段,而之前使用的是标准的C++压缩。测试基准表明,峰值区域的内存缩减平均可以达到40%左右。

上面所描述的所有改进将出现在Chrome 55版本里,希望今年12月份可以放出。

查看英文原文:Profiling and Optimizing V8 Memory Consumption


感谢夏雪对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ@丁晓昀),微信(微信号:InfoQChina)关注我们。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT