开源 _ 新一代Android 性能监控框架Rabbit

慢函数检测

基于编译时代码插桩, rabbit可以准确的统计每一个函数的耗时,并筛选出慢函数

慢函数定义为: 在主线程消耗时间超过一定阈值的函数(rabbit也支持配置检测其他线程的慢函数)。

rabbit支持分包检测慢函数:

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

支持查看每一个包下的慢函数列表以及每一个慢函数的堆栈:

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

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

代码扫描

通过提供给rabbit一份代码扫描列表,rabbit可以在编译时扫描出这些代码调用的位置。默认会扫描一些阻塞代码, 比如下面这种:

SharePreferences$Editor.commit()

最终扫描结果会展示如下:

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

点击右上角导出按钮可以把扫描结果以json的形式导出到SD卡中。

网络日志监控

rabbit可以记录网络请求日志并方便的查看返回的json数据:

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

卡顿日志监控


rabbit通过Choreographer来检测主线程的运行情况,并异步采集主线程堆栈来还原卡顿现场。

对于下面代码:

Thread.sleep(2000)

rabbit会获得如下的卡顿采集结果:

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

FPS分析

rabbit会在主线程looper运行时计算主线程FPS并实时的显示出来:

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

rabbit支持分页面分析FPS:

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

内存分析

功能类似于FPS分析,rabbit支持实时显示内存使用情况并分页面分析内存占用情况:

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

分页面内存统计:

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

异常捕获

通过设置Thread.setDefaultUncaughtExceptionHandler,rabbit可以捕获java层异常并展示出来:

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

内存泄漏捕获

rabbit集成了leakcanary 2.0

apk包分析

rabbit提供了一个可执行的jar包, 它可以准确的分析出apk中的大图、重复文件、apk包大小与内容组成。核心思路参考自Matrix APK包分析

运行方式为:

java -jar apk-analyzer.jar apk-analyzer-config.json

apk-analyzer-config.json用来配置待分析的apk路径以及mapping文件位置等信息:

{
“apkPath”:“xxxx/app-Release.apk”,
“methodGroup”:[{
“name”:“xxx”,
“package”:“com.xxx.xx”
}],
“classMappingFilePath”:“xxx/xxx.txt”,
“maxImageSizeKB”:30
}

最终分析结果会输出到一个json文件中:

apk-analyzer-result.json

{
“AppInfo”: {
“versionCode”: “1004000”,
“versionName”: “1.4.0”,
“appSize”: “21.51 MB”
},
“BigImageRes”: [
{
“name”: “assets/flutter_assets/images/icons/xxLogo.png”,
“size”: “76.73 KB”
}


],
“ApkCompose”: [
{
“type”: “so”,
“totalSizeStr”: “8.05 MB”
},
{
“type”: “dex”,
“totalSizeStr”: “6.54 MB”
}


],
“DuplicatedFile”: [
{
“files”: [
“res/drawable-xxhdpi-v4/bg_home_water_ripple.webp”,
“res/drawable-xxhdpi-v4/bg_keyboard_shadow_line.webp”
],
“fileSize”: “”,
“md5Value”: “d41d8cd98f00b204e9800998ecf8427e”
}

],
“MethodCount”: {
“total-count”: 127732,
“com.xxx.xx”: 14800,
“other-pkg”: 112932
}
}

上报APK分析结果

需要在apk-analyzer-config.json中配置上报路径:

{
“apkPath”:“xxxx/app-Release.apk”,

“uploadPath”:“xxxxxx/upload”
}

上报的数据格式与rabbit的基本上报数据格式保证一致:

数据上报

rabbit目前支持上报大部分检测数据。通过一些简单的配置就可以把检测数据上报到后台。rabbit数据上报的基本格式如下:

{
“device_info_str”: “{…}”,
“info_str”: “{…}”,
“time”: 1577775888933,
“type”: “fps_info”,
“use_time”: 19
}

  • type : 上报的数据类型
  • device_info_str : 设备信息, 格式json字符串
  • info_str: 该类型的数据的具体内容, 格式为json字符串
  • use_time: 应用当前使用时长

rabbit提供了上报回调,可以通过这个回调很方便的来实现自定义的上报逻辑:

rabbitConfig.reportConfig.dataReportListener = object :RabbitReportConfig.DataReportListener{
override fun onPrepareReportData(data: Any, currentUseTime: Long) {
//接入自己的上报逻辑
}
}

自定义面板

rabbit向外提供了UI扩展API,使用这些API可以很方便的把应用的“后门“放到rabbit中。

具体操作见 : 在rabbit中自定义页面

可用性与可配置性

rabbit的接入十分简单, 基本上就是一个init代码:

Rabbit.init(rabbitConfig)

相关支持配置见:RabbitConfig

对于每一个功能,rabbit都提供了丰富的配置API和详细的使用文档

在rabbit控制面板中你也可以很方便的控制这些功能:

监控开关设置

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

快捷功能

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

查看当前配置

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

noop包

rabbit目前没有经过线上环境的验证,为了方便接入,提供了noop包。

具体引入步骤见 引入noop包

noop包中可以继续使用rabbit的UI功能

代码结构

rabbit并没有使用什么很特别架构,不过各功能间都使用module的形式做了组件隔离:

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

后续开发计划

完善现有功能

rabbit目前提供的功能还比较简单,接下来会更细致的完善每一个功能来提高可用性。

性能测量模式

最后

小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、电子书籍、讲解视频,并且后续会持续更新

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人

都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

如果你需要这些资料, ⬅ 专栏获取
]

[外链图片转存中…(img-zBZkhmwK-1719457139197)]

[外链图片转存中…(img-ZtPszAlq-1719457139198)]

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、电子书籍、讲解视频,并且后续会持续更新

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人

都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

如果你需要这些资料, ⬅ 专栏获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值