初探Matrix Android ApkChecker
背景
因为我所在的项目是做投放包,对安卓包的大小很敏感,经常会优化包的大小,所以想引入工具静态检测包大小,看能不能找到其中可以优化的地方,防患于未然。Matrix是微信终端自研和正在使用的一套APM(Application Performance Management)系统。 Matrix-ApkChecker作为Matrix系统的一部分,是针对android安装包的分析检测工具,根据一系列设定好的规则检测apk是否存在特定的问题,并输出较为详细的检测结果报告,用于分析排查问题以及版本追踪。Matrix-ApkChecker以一个jar包的形式提供使用,通过命令行执行 java -jar ApkChecker.jar 即可运行。
Matrix-ApkChecker的使用
在git上下载matrix-apk-canary-0.4.10.jar
直接在命令行执行
java -jar ApkChecker.jar
即可以查看Matrix-ApkChecker的使用说明 (注意:下面所说的路径为完整路径,非相对路径)
Matrix-ApkChecker的命令行参数比较多,主要包括global参数和option参数两类:
- global
--apk 输入apk文件路径(默认文件名以apk结尾即可)
--mappingTxt 代码混淆mapping文件路径 (默认文件名是mapping.txt)
--resMappingTxt 资源混淆mapping文件路径(默认文件名是resguard-mapping.txt)
--input 包含了上述输入文件的目录(给定--input之后,则可以省略上述输入文件参数,但上述输入文件必须使用默认文件名)
--unzip 解压apk的输出目录
--output 输出结果文件路径(不含后缀,会根据format决定输出文件的后缀)
--format 结果文件的输出格式(例如 html、json等)
--formatJar 实现了自定义结果文件输出格式的jar包
--formatConfig 对结果文件输出格式的一些配置项(json数组格式)
global 参数之后紧跟若干个 Option,这些 Option 是可选的,一个 Option 表示针对 apk 的一个检测选项。
- option参数
- manifest 从AndroidManifest.xml文件中读取apk的全局信息,如packageName、versionCode等。
- fileSize 列出超过一定大小的文件,可按文件后缀过滤,并且按文件大小排序
--min 文件大小最小阈值,单位是KB
--order 按照文件大小升序(asc)或者降序(desc)排列
--suffix 按照文件后缀过滤,使用","作为多个文件后缀的分隔符
- countMethod 统计方法数
group 输出结果按照类名(class)或者包名(package)来分组
- checkResProguard 检查是否经过了资源混淆 (AndResGuard)
- findNonAlphaPng 发现不含alpha通道的png文件
- checkMultiLibrary 检查是否包含多个ABI版本的动态库
- uncompressedFile 发现未经压缩的文件类型(即该类型的所有文件都未经压缩)
suffix 按照文件后缀过滤,使用","作为多个文件后缀的分隔符
- countR 统计apk中包含的R类以及R类中的field count
- duplicatedFile 发现冗余的文件,按照文件大小降序排序
- checkMultiSTL 检查是否有多个动态库静态链接了STL
- unusedResources 发现 apk 中包含的无用资源
rTxt R.txt文件的路径(如果在全局参数中给定了--input,则可以省略)
ignoreResources 需要忽略的资源,使用","作为多个资源名称的分隔符
- unusedAssets 发现apk中包含的无用assets文件
- ignoreAssets 需要忽略的assets文件,使用","作为多个文件的分隔符
- unstrippedSo 发现apk中未经裁剪的动态库文件
除了直接在命令行中带上详细参数外,也可以将参数配置以 json 的格式写到一个配置文件中,然后在命令行中使用
指定配置文件的路径。一个典型的配置文件格式如下:
{
"--apk": "/xxx",
"--formatConfig": [
{
"group": [
{
"name": "Android System",
"package": "android"
},
{
"name": "java system",
"package": "java"
},
{
"name": "xxx",
"package": "com.xxx"
}
],
"name": "-countMethod"
}
],
"--format": "mm.html,mm.json",
"options": [
{
"name": "-manifest"
},
{
"--suffix": "png, jpg, jpeg, gif, arsc",
"--min": "10",
"name": "-fileSize",
"--order": "desc"
},
{
"--group": "package",
"name": "-countMethod"
},
{
"name": "-checkResProguard"
},
{
"--min": "10",
"name": "-findNonAlphaPng"
},
{
"name": "-checkMultiLibrary"
},
{
"--suffix": "png, jpg, jpeg, gif, arsc",
"name": "-uncompressedFile"
},
{
"name": "-countR"
},
{
"name": "-duplicatedFile"
},
{
"name": "-unusedAssets",
"--ignoreAssets": [
"*.so"
]
}
],
"--output": "/xxx"
}
其中,mm.html 和 mm.json 是微信使用的自定义输出格式,Matrix-ApkChecker 默认提供 html 、json、mm.html 以及 mm.json 四种输出格式。
要注意的是所有路径都必须是绝对路径,如果是windows系统的话复制文件夹的路径是反斜杠(),会报转义错误,改为正斜杠(/)
使用配置文件命令如下:
java -jar matrix-apk-canary-0.4.10.jar --config 配置文件路径
输出这么一串代码就代表执行成功
Matrix-ApkChecker的功能
- 读取manifest的信息
从AndroidManifest.xml文件中读取apk的全局信息,如packageName、versionCode等
- 按文件大小排序列出apk中包含的文件
列出超过一定大小的文件,可按文件后缀过滤,并且按文件大小排序
- 统计方法数
统计dex包含的方法数,并支持将输出结果按照类名(class)或者包名(package)来分组
- 检查是否经过了资源混淆(AndResGuard)
检查apk是否经过了资源混淆,推荐使用资源混淆来进一步减小apk的大小
- 搜索不含alpha通道的png文件
对于不含alpha通道的png文件,可以转成jpg格式来减少文件的大小
- 检查是否包含多个ABI版本的动态库
so文件的大小可能会在apk文件大小中占很大的比例,可以考虑在apk中只包含一个ABI版本的动态库
- 搜索未经压缩的文件类型
某个文件类型的所有文件都没有经过压缩,可以考虑是否需要压缩
- 统计apk中包含的R类以及R类中的field count
编译之后,代码中对资源的引用都会优化成int常量,除了R.styleable之外,其他的R类其实都可以删除
- 搜索冗余的文件
对于两个内容完全相同的文件,应该去冗余
- 检查是否有多个动态库静态链接了STL
如果有多个动态库都依赖了STL,应该采用动态链接的方式而非多个动态库都去静态链接STL
- 搜索apk中包含的无用资源
apk中未经使用到的资源,应该予以删除
- 搜索apk中包含的无用assets文件
apk中未经使用的assets文件,应该予以删除
- 搜索apk中未经裁剪的动态库文件
动态库经过裁剪之后,文件大小通常会减小很多
示例分析
下面,我们对一个示例apk使用Matrix-ApkChecker进行检查,并根据检查的结果进行针对性的减包优化。
从Matrix-ApkChecker的输出结果中可以看到示例apk的相关全局信息如下图所示:
示例 apk 中包含的文件按类型统计如下图所示:
png文件(不包括 .9.png)未经压缩,可以考虑一定程度的压缩
存在一些冗余的文件,文件内容相同的文件应该只保留一份
存在无用资源,包括未使用的系统support包中的资源、第三方资源包中的无用资源以及示例app定义的资源
存在无用的assets资源,应该删除
后续
了解完Matrix-ApkChecker的基本功能后,后续考虑集成到jenkins中,每次编译产出Apk时运行脚本记录apk的总大小值,对比每个版本的包大小总值,dex、so、图片资源各自占比、是否有重复资源、是否有图片未压缩等,如果能每个版本检查出上述问题并提出优化建议,那么在持续集成中价值就比较大
参考
https://github.com/Tencent/matrix/wiki/Matrix-Android-ApkChecker
初探Matrix Android ApkChecker的更多相关文章
- Matrix: android 中的Matrix (android.graphics.Matrix) (转)
本篇博客主要讲解一下如何处理对一个Bitmap对象进行处理,包括:缩放.旋转.位移.倾斜等.在最后将以一个简单的Demo来演示图片特效的变换. 1. Matrix概述 对于一个图片变换的处理,需要Ma ...
- Android ViewPager再探:增加滑动指示条
上一篇:<Android ViewPager初探:让页面滑动起来> ViewPager只是左右滑动有些丑,也不知道当前位于第几页面. 可以在上方加入滑动指示条,来确定当前位置. 只需要修改 ...
- 收藏的Android学习资源
1. Android中混合开发系列 Android中Java与JavaScript的交互,可用来实现网页与本地APP的交互,信息的传递等: 谈谈App的混合开发,可以让一部分功能由html5开发,这部 ...
- android tab选项卡的使用
项目做完了,写写博客,在项目中遇到的一些问题,或者是自己觉得很不错的东西.这一篇主要是想和大家分享一下我在项目中封装的一个东西,就是tab选项卡.先看看效果图: 我在网上看了很多有关选项卡的demo, ...
- android 图片浏览器
自定义了gallary和ImageView: gallary: public class MyGallery extends Gallery { /** * GestureDetector类 在on ...
- Android学习笔记(九) 视图的应用布局效果
最近少了写博客,可能最近忙吧,工作上忙,因为工作原因也忙于学习,也没记录什么了,也没有按照之前的计划去学习了.现在就记录一下最近学到的. 要做Android应用,界面设计少不了,可惜之前一直在用Win ...
- java攻城狮之路(Android篇)--MP3 MP4、拍照、国际化、样式主题、图片移动和缩放
一.MP3播放器 查看Android API文档可以看到MediaPlayer状态转换图: 练习: package com.shellway.mp3player; import java.io.Fil ...
- android实现点击背景图片不同区域实现不同事件
有时候我们拿到一张背景图片,客户要求点击图片的不同区域去跳转或者实现不同的操作事件.我们首先要确认图片的点击区域,往往我们会在布局文件那里下手,但是这样不好做适配,所以我实现了以下方法,基本功能可以实 ...
- Android ViewPager使用详解
这是谷歌官方给我们提供的一个兼容低版本安卓设备的软件包,里面包囊了只有在安卓3.0以上可以使用的api.而viewpager就是其中之一利用它,我们可以做很多事情,从最简单的导航,到页面菜单等等.那如 ...
随机推荐
- 第10组 Alpha冲刺 (5/6)
1.1基本情况 ·队名:今晚不睡觉 ·组长博客:https://www.cnblogs.com/cpandbb/p/13996848.html ·作业博客:https://edu.cnblogs.co ...
- 关于APP设计规范和一些图层命名
首先,本人大学计算机专业出身,学过编程,工作的时候做过 产品经理,设计师,前端工程师,对工作的流程都有一些见解. 现在主攻前端工程师,做Web APP.今天收到设计师的设计稿,一看图层分类,这让我感觉 ...
- Jmeter中用例禁用
1.在线程组下创建2个http请求(blogs和baidu),并且在Thread Group 添加[View Results Tree]和[View Results in Table] 2.选择[ba ...
- Pytorch之Spatial-Shift-Operation的5种实现策略
Pytorch之Spatial-Shift-Operation的5种实现策略 本文已授权极市平台, 并首发于极市平台公众号. 未经允许不得二次转载. 原始文档(可能会进一步更新): https://w ...
- Solon 开发,五、切面与环绕拦截
Solon 开发 一.注入或手动获取配置 二.注入或手动获取Bean 三.构建一个Bean的三种方式 四.Bean 扫描的三种方式 五.切面与环绕拦截 六.提取Bean的函数进行定制开发 七.自定义注 ...
- 【get√】发现一个redis zset的新玩法:用ZINTERSTORE把value都置0
直接上指令: redis-cli -h 192.168.0.5 -p 6379 -a test123 DEL __temp_ahfu1 ZADD __temp_ahfu1 1 0.0.18.185_0 ...
- uniapp如何生成自己的小程序码并且携带参数
生成小程序码需要用到的参数appId appSecret这两个参数可以再微信公众平台里面登录获取 也可以用测试号里面的获取小程序码步骤1.首先要请求官方的API`https://api.weixin ...
- threejs - src - WebGLProgram是如何组建Shader的?
threejs - src - WebGLProgram是如何组建Shader的? WebGLProgram的构建 WebGLProgram构建的时候需要的参数如下: // \param render ...
- 前端基础之javaScript(基本类型-布尔值数组-if-while)
目录 一:javaScript基本数据类型 1.字符串类型常用方法 2.返回长度 3.移出空白 4.移除左边的空白 5.移出右边的空格 6.返回第n个字符 7.子序列位置 8.根据索引获取子序列 9. ...
- K8S探针和SVC,POD原理
(6)容器是否健康: spec.container.livenessProbe.若不健康,则Pod有可能被重启(可配置策略) (7)容器是否可用: spec.container.readiness ...