Android build 性能

报告问题 查看源代码 每夜 build · 7.4 .

本页面专门介绍了如何优化 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 个永久性工作器。我们通过将每个操作的实例数量上限设为 12衡量了构建性能的提升,不过这可能会因 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_binaryandroid_local_testaapt_version 上设置 aapt2

SSD 优化

--experimental_multi_threaded_digest 标志有助于优化 SSD 上的摘要计算。