Android build 性能

本页内容介绍了如何专门针对 Android 应用优化构建性能。如需了解如何使用 Bazel 优化构建性能,请参阅优化性能

标志包含在 bazelrc 配置语法中,因此可以直接粘贴到 bazelrc 文件中,并在命令行中使用 --config=<configuration_name> 进行调用。

性能分析

默认情况下,Bazel 会将 JSON 跟踪记录配置文件写入 Bazel 输出库中名为 command.profile.gz 的文件中。请参阅 JSON 配置文件文档,了解如何读取配置文件并与之互动。

执行 Android 构建操作的持久性工作器

部分 Android 构建操作支持持久性 worker

这些操作的助记符包括:

  • DexBuilder
  • 爪哇语
  • 脱糖
  • 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_test 上的 aapt_version 上设置 aapt2

SSD 优化

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