快速批量统计aar包大小

本文介绍了58同城在aar包大小统计监控的实践。

《春晓 》
春眠不觉晓,处处闻啼鸟。
夜来风雨声,花落知多少?
-孟浩然

背景

随着业务版本不断的迭代,apk变得越来越大,每个版本上线后需要产出各个业务所占大小分析报告,以便实现对各业务包大小增长曲线的监控,方便为减少包大小提供有力依据,目前业内并没有一个很好的办法计算aar在apk中的大小。为什么不直接看AAR文件大小?因为aar中可能包含多架构so,实际应用并不会使用多架构so。

问题

由于58app可以通过全aar依赖,app工程只是一个壳工程,所以我们可以获取依赖树后在一个demo工程中依赖待计算的aar,然后计算依赖前后的大小差产出aar大小,但如果待计算的AAR有pom依赖其他AAR时,移除pom依赖后可能由于资源缺失导致打包失败。这时便无法计算出指定aar在apk中所占大小。

这里的资源缺失包含两个问题:一是图片等资源的缺失,二是清单文件中的placeholder的缺失。

解决方案

从报错日志可以看出,如果缺失资源aapt2在执行link过程中会报资源找不到,由于我们只是想计算出aar在apk中所占大小,并不关注产出的apk能否运行,所以我们可以通过修改aapt2源码在资源找不到时统一修改为从demo工程查找固定名称的资源,如果我们在编译时出现报错无法找到相关资源时,只需要在demo工程创建同类型的固定名称占位资源(ids.xml)即可。关于aapt的编译请查看自己动手编译全平台aapt

关于第二个问题清单文件中的placeholder的缺失,可以通过修改gradle插件源码,给placeholder指定固定值来解决。

在Demo工程中配置需要的cpu架构和远程仓库,然后在Demo工程中先打出一个基础apk并获取大小,再将aar依赖添加到Demo工程中获取对应aar包的大小。为了简化这一流程可以先获取原工程的依赖树后,在Demo工程通过使用Python脚本自动化。

业务的独有依赖

由于实际情况是根据业务来统计大小的,通过依赖树并不能完全正确分析出aar所属业务,考虑到每个版本的aar变动较小,所以我们是通过配置文件手动根据实际情况将业务aar归属到同一分组中,最终产出该业务所占大小以及包含的aar列表。

本地产出结果

根据上述步骤我们实现了在终端执行一行python脚本命令便可以自动化产出所有业务大小:

最终成果

为了方便监控和快速产出每个版本的数据,我们做了一个简单易用的可视化平台,通过在远程服务器执行打包最后将产出的数据上传到后台,可以自动产出报告并发送邮件,极大提升了产出报告的效率。


图一 各版本包大小统计图


图二 业务大小曲线图


图三 版本aar包大小详情
在详情页面可以查看每个业务的大小及对应包含的aar详情列表,也可以选择版本进行对比查看增量大小。

总结

通过修改aapt源码和gradle插件源码解决了由于资源缺失导致的打包失败问题,通过获取依赖树在Demo工程中使用python脚本自动化产出aar大小数据,最后通过可视化平台极大提升了包大小报告产出的效率。

如需Demo工程源码,微信搜索关注“于卫国”公众号回复“aar”获取。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • 博客已迁移至:https://leeon7.github.io[https://leeon7.github.io]...
    leeon7阅读 16,164评论 13 51
  • 一、瘦身优化及 Apk 分析方案介绍 1.1 瘦身优势 我们首先来介绍下,为什么我们需要做 APK 的瘦身优化? ...
    凯玲之恋阅读 645评论 0 0
  • 本文会不定期更新,推荐watch下项目。如果喜欢请star,如果觉得有纰漏请提交issue,如果你有更好的点子可以...
    天之界线2010阅读 18,072评论 19 154
  • 本文介绍了几种减少包大小的技术方案,希望能够帮到你。 《虞美人·春花秋月何时了》春花秋月何时了?往事知多少。小楼昨...
    于卫国阅读 911评论 0 3
  • 夜莺2517阅读 127,664评论 1 9