使用有限 RAM 运行 Bazel

报告问题 查看源代码

本页介绍了如何使用标志针对有限的 RAM 运行 Bazel。

在某些情况下,您可能希望 Bazel 使用最少的内存。您可以通过启动标志 --host_jvm_args(例如 --host_jvm_args=-Xmx2g)设置最大堆。

但是,如果构建足够大,Bazel 可能会在内存不足时抛出 OutOfMemoryError (OOM)。您可以通过传递以下命令标志,让 Bazel 使用更少的内存,但代价是增量构建速度变慢:--discard_analysis_cache--nokeep_state_after_build--notrack_incremental_state

这些标志会最大限度地减少 Bazel 在构建中使用的内存,但代价是会使未来的构建速度低于标准增量构建的速度。

您也可以单独传递以下任一标志:

  • --discard_analysis_cache 会减少执行期间使用的内存(而非分析)。增量构建无需重做软件包加载,但必须重做分析和执行(尽管磁盘上的操作缓存可以阻止大多数重新执行)。
  • --notrack_incremental_state 不会将任何边存储在 Bazel 的内部依赖关系图中,因此无法用于增量构建。下一个 build 会舍弃该数据,但在此之前会保留这些数据以进行内部调试,除非指定了 --nokeep_state_after_build
  • --nokeep_state_after_build 会在构建后舍弃所有数据,因此必须从头开始构建增量构建(磁盘操作缓存除外)。仅这一项不会影响当前 build 的高水位标记。