Android 性能监控系列一(原理篇)

本文探讨了在Android应用中引入APM框架的原因,重点介绍了数据采集的自动化方法,特别是通过字节码插桩技术实现的性能优化。作者提到了ASM和Javassist在字节码处理中的角色,以及如何利用GradlePlugin进行插桩。此外,还强调了系统化学习的重要性,邀请读者加入技术交流社群。
摘要由CSDN通过智能技术生成

这里要向大家交代一点是,之前的文章为了极力做到将复杂的问题用通俗易懂的方式解释清楚,又要面面俱到,往往篇幅过长;诸如之前写过的RxJava系列6(从微观角度解读RxJava源码)神兵利器Dagger2安居客 Android 项目架构演进Android 模块化探索与实践写给 Android 应用工程师的 Binder 原理剖析等文章,篇幅通常都在 8000~10000字以上,通篇阅读下来可能需要近半个小时的时间,不太符合当下碎片化阅读的需求;因此在后面的写作上会控制篇幅,尽量控制在 10 分钟以内的长度。

这也是我为什么会将 APM 作为一个系列来介绍的原因,同时这也能保证后面在介绍 APM 的时候能够深入到实现细节,避免泛泛而谈。

二. Android APM 的基本原理

市场上有很多商业化的 APM 平台,比如著名的 NewRelic,还有国内的 听云、OneAPM 等等。这些平台的工作流程基本都是一致的:

  1. 首先在客户端(Android、iOS、Web等)采集数据;
  2. 接着将采集到的数据整理上报到服务器;
  3. 服务器接收到数据后建模、存储、挖掘分析,让后将数据可视化,供用户使用。

如下图:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

我们介绍的 Android APM 框架其实就是在 Android 平台上应用的一个数据采集上报 SDK。主要包含三大模块:

  1. 数据采集
  2. 数据存储
  3. 数据上报

其中数据采集是整个 APM 框架的核心。

数据采集我们可以通过手动埋点的方式,但这种方式工作量巨大、不灵活,而且无法覆盖到所有场景;因此只能通过自动化的方式来采集数据。在应用构建期间,通过修改字节码的方式来进行字节码插桩就是实现自动化的方案之一。

三. Android 打包流程及字节码插桩原理

在谈字节码插桩的原理之前,首先我们看看 Android 的打包流程,如下图:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

从上面这张打包流程图我们可以看到,一个 App 的所有 class 文件,包括第三方的 class 文件都会经过 dex 的过程打包成一个或者多个 dex 文件。

这其中涉及到两个很关键的环节:

  1. javac:将 .java 格式的源代码文件编译成 class 文件;
  2. dex: 将 class 格式的文件打包汇总,组成一个或者多个 dex 文件。

我们想要对字节码进行修改,只需要在 javac 之后 dex 之前遍历所有的字节码文件,并按照一定的规则过滤修改就好了,这里便是字节码插桩的入口。

那么我们到底如何介入打包过程,在 class 转换为 dex 文件的时候实现对字节码的修改呢?

答案是 transform api

Android Gradle Plugin 1.5.0 及以上版本,Google 官方提供了 transform api 作为字节码插桩的入口。我们只需要实现一个自定义的 Gradle Plugin,然后在编译阶段去修改字节码文件。对于 Gradle Plugin 的具体实现后面的文章再做详细讲解。

四. 修改字节码

找到了插桩入口,接下来就要对字节码进行修改。对于字节码的修改,比较常用的框架有 Javassist 和 ASM。

  1. Javassist 是一个开源的分析、编辑和创建 Java 字节码的类库,它提供了源码级别的 API 以及字节码级别的 API,源码级别的 API,直接使用 Java 编码的形式,而不需要深入了解虚拟机指令,就能动态改变类的结构或者动态生成类。

  2. ASM 是一个 Java 字节码操控框架。它能被用来动态生成类或者增强既有类的功能。ASM 可以直接产生二进制 class 文件,也可以在类被加载入 Java 虚拟机之前动态改变类行为。

ASM 和 Javassit 相比,API 贴近底层,比较难使用,需要对 Java 字节码和虚拟机方面有一定程度的了解。ASM 的优点就在于性能上的优势,且更加灵活;Javassist 的实现中大量使用的反射,所以性能偏低。

简单的说就是 ASM 虽然难以使用,但是功能强大效率高。是很多无痕埋点、APM框架的首选方案。

ASM 的具体时候我们放到这个系列后面的文章介绍。

最后

在此为大家准备了四节优质的Android高级进阶视频:

架构师项目实战——全球首批Android开发者对Android架构的见解

附相关架构及资料

image.png

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值