智能体刷屏的背后,是 AI 应用拐点的来临?AICon 北京站议程重磅公布,50+ 硬核分享不容错过 了解详情
写点什么

Lyft 如何检测生产中安卓的内存泄漏

  • 2023-03-22
    北京
  • 本文字数:849 字

    阅读完需:约 3 分钟

Lyft如何检测生产中安卓的内存泄漏

尽管现代的安卓和 iOS 工具都能通过本地构建检测内存泄露风险,但应用程序在生产环境中的内存表现却依旧得不到百分百的保障。生产环境中的程序可能在各种条件下运行在各种设备上,为此,Lyft的工程师将A/B测试与内存可观察性相结合,从而检测可能造成内存泄漏的应用功能。


在发布大型且复杂的功能点时,我们需要特别关注其在内存使用方面是否会造成回归。这点在包含本地 C/C++代码的功能发布时更为关键,因为这部分代码更易于引入内存泄漏。


在一般情况下,Lyft 工程师所遵循的方式是用测量的应用程序的标准内存行为基线,对比在 A/B 测试中所采集的特定功能受众子群数据。在评估应用的整体内存使用上,Lyft 工程师考虑了几款安卓上可用来检索内存使用指标的API:比例集大小(PSS)、唯一集大小(USS)、常驻内存大小(RSS)。其中 RSS 因其在性能方面的特点,以及可以不受采样率限制的特性而脱颖而出。其他 Lyft 工程师们感兴趣的指标,如 JVM 堆和本地堆大小等,都支持在安卓运行时直接采集。


内存指标的重要采集场景有两种:每次 UI 界面关闭时,以及用户在同一界面长时间停留的情况下每分钟的采集间隔。


因此,为判断一项功能是否会造成内存回归,Lyft 工程师对比了用户群组在运行禁用该功能时的原始版本,与启用该功能应用版本的情况。内存使用情况随用户而异,故而将应用内存使用足迹以曲线形式显示,如果两种情况下内存足迹曲线出现,则表示可能存在内存回归情况,如下图表示:



一个有趣的发现是,内存泄漏只影响一小部分用户。因此,除了百分比较高的部分(取决于用户群组大小),内存足迹曲线实际是会几乎重合的。如下图中所示,内存泄漏只会发生在极特殊的情况下,仅影响用户群组的最后一段百分比。



Lyft 的工程师称,这种方式已被证明可以有效检测内存泄漏,尤其是特殊情况下极易在本地测试时遗漏的内存泄露。还请不要错过 Lyft 原文中的全部细节。


原文链接

How Lyft Detects Android Memory Leaks in Production


相关阅读:

探索 Android 14:首个开发者预览版的新功能与特性

Spotify 移动工程平台迁移:将 Android 和 iOS 代码库迁移到 Bazel

2023-03-22 08:008242

评论

发布
暂无评论
发现更多内容

week02 题目

xxx

架构第二周课后练习

Geek_Gu

极客大学架构师训练营

架构训练营第二周学习总结

灰羽零

架构师训练营Week02作业

IT老兵重开始

极客大学架构师训练营

第二周作业

kevin

架构师训练营第 1 期 -Week2 - 框架设计学习总结

鲁大江

极客大学架构师训练营 面向对象设计原则 框架设计

架构一期二班 - 吴水金 - 第二课总结

吴水金

逆序局部链表、Paxos算法原理、架构师发现问题所在 John 易筋 ARTS 打卡 Week 19

John(易筋)

ARTS 打卡计划 发现问题的真正所在 逆序局部链表

【FastDFS】面试官:如何实现文件的大规模分布式存储?(全程实战)

冰河

高并发 高性能 分布式存储 fastdfs 海量存储

架构师训练营第一期 - 第二周学习总结

卖猪肉的大叔

训练营-第二周-作业二

行者

面向对象编程与软件设计原则

zero2onemore

第二周 框架设计 学习总结

应鹏

学习 极客大学架构师训练营

week02总结

xxx

问题集锦:DBType not support : null

互联网应用架构

mybaitsplus

架构师训练营第一期第2周作业及总结

木头发芽

medo 支付系统架构设计

陈皮

Spring 5 中文解析数据存储篇-JDBC数据存储(中)

青年IT男

Spring5

作业二:第二周学习总结

静海

第二周总结

Week_02

golangboy

架构师训练营1期3班-袭望-第二周

袭望

训练营-第二周-作业一

行者

艺术家们手握“飞桨” 划出金秋UCCA最值得一看的AI艺术展

脑极体

第二周学习总结

alpha

极客大学架构师训练营

第二周课后练习 - 作业 2

致星海

第二周作业

一篇搞定前端高频手撕算法题(36道)

执鸢者

面试 算法 大前端

架构师训练营作业:第二周

m

第二周课后练习-作业1

致星海

第二周总结

_

极客大学架构师训练营 第二周总结

Lyft如何检测生产中安卓的内存泄漏_移动_Sergio De Simone_InfoQ精选文章