Android build 性能

报告问题 查看源代码

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

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

性能分析

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

用于 Android 构建操作的永久性工作器

部分 Android 构建操作支持永久性工作器

这些操作的助记符包括:

  • 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_test 上的 aapt_version 上设置 aapt2

SSD 优化

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