本页面专门介绍了如何优化 Android 应用的 build 性能。如需了解使用 Bazel 进行常规构建性能优化,请参阅优化性能。
建议的标志
这些标志采用 bazelrc
配置语法,因此可以直接粘贴到 bazelrc
文件中,并在命令行上使用 --config=<configuration_name>
调用。
性能分析
Bazel 默认会将 JSON 轨迹配置文件写入 Bazel 输出基目录中名为 command.profile.gz
的文件。如需了解如何读取配置文件并与其互动,请参阅 JSON 配置文件文档。
适用于 Android build 操作的永久性工作器。
部分 Android build 操作支持永久性 worker。
这些操作的助记符如下:
- DexBuilder
- Javac
- 脱糖
- AaptPackage
- AndroidResourceParser
- AndroidResourceValidator
- AndroidResourceCompiler
- RClassGenerator
- AndroidResourceLink
- AndroidAapt2
- AndroidAssetMerger
- AndroidResourceMerger
- AndroidCompiledResourceMerger
启用 worker 可以通过减少调用每种工具的 JVM 启动开销来提升构建性能,但代价是系统的内存用量会增加,因为这些工具会保留在系统中。
如需为这些操作启用工作器,请在命令行中使用 --config=android_workers
应用这些标志:
build:android_workers --strategy=DexBuilder=worker
build:android_workers --strategy=Javac=worker
build:android_workers --strategy=Desugar=worker
# A wrapper flag for these resource processing actions:
# - AndroidResourceParser
# - AndroidResourceValidator
# - AndroidResourceCompiler
# - RClassGenerator
# - AndroidResourceLink
# - AndroidAapt2
# - AndroidAssetMerger
# - AndroidResourceMerger
# - AndroidCompiledResourceMerger
build:android_workers --persistent_android_resource_processor
默认情况下,系统会为每项操作创建 4
个永久性工作器。我们通过将每个操作的实例数量上限设为 1
或 2
,衡量了构建性能的提升,不过这可能会因 Bazel 所运行的系统和要构建的项目而异。
如需限制操作的实例数量,请应用以下标志:
build:android_workers --worker_max_instances=DexBuilder=2
build:android_workers --worker_max_instances=Javac=2
build:android_workers --worker_max_instances=Desugar=2
build:android_workers --worker_max_instances=AaptPackage=2
# .. and so on for each action you're interested in.
使用 AAPT2
与 aapt
相比,aapt2
的性能有所提升,并且创建的 APK 也更小。如需使用 aapt2
,请使用 --android_aapt=aapt2
标志,或在 android_binary
和 android_local_test
的 aapt_version
上设置 aapt2
。
SSD 优化
--experimental_multi_threaded_digest
标志对于优化 SSD 上的摘要计算非常有用。