Bazel 路线图

报告问题 查看源代码 每夜 build · 8.0 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

概览

为了满足您的需求,Bazel 项目会不断发展,因此我们想分享一下 2024 年的更新。

此路线图介绍了当前的计划和对 Bazel 未来发展的预测,让您可以了解当前的优先事项和正在进行的项目。

Bazel 8.0 版本

我们计划在 2024 年底为您提供 Bazel 8.0 长期支持 (LTS)。我们计划实现以下功能。

Bzlmod:外部依赖项管理系统

Bzlmod 会自动解析传递依赖项,让项目能够在保持快速和资源高效的同时进行扩展。

在 Bazel 8 中,我们将默认停用 WORKSPACE 支持(您仍然可以使用 --enable_workspace 启用该支持);在 Bazel 9 中,我们将移除 WORKSPACE 支持。从 Bazel 7.1 开始,您可以设置 --noenable_workspace 以选择启用新行为。

Bazel 8.0 将对 Bazel 的外部依赖项管理功能进行多项增强,包括:

  • 您可以将新标志 --enable_workspace 设置为 false,以完全停用 WORKSPACE 功能。
  • 新的目录监控 API(请参阅 #21435,已在 Bazel 7.1 中发布)。
  • 改进了用于生成规范代码库名称的方案,以便在依赖项版本更新后更好地缓存操作。(#21316,已在 Bazel 7.1 中发布)
  • 改进了共享代码库缓存(请参阅 #12227)。
  • 供应商和离线模式支持 - 允许用户运行包含预下载依赖项的 build(请参阅 #19563)。
  • 减少了锁定文件中的合并冲突 (#20396)。
  • 分段 MODULE.bazel (#17880)
  • 允许替换模块扩展程序生成的代码库 (#19301)
  • 改进了文档(例如 #18030#15821)、迁移指南和迁移工具。

远程执行方面的改进

  • 添加了对异步执行的支持,通过使用标志 --jobs 提高并行性来加快远程执行速度。
  • 通过新的紧凑型执行日志,更轻松地调试缓存未命中问题,其大小缩减了 100 倍,运行时开销也显著降低(请参阅 #18643)。
  • 为磁盘缓存实现垃圾回收(请参阅 #5139)。
  • 实现了远程输出服务,以允许延迟下载任意 build 输出(请参阅 #20933)。

迁移 Android、C++、Java、Python 和 Proto 规则

将 Android、C++、Java 和 Python 规则集完全迁移到专用代码库,并将其与 Bazel 版本解耦。通过这项工作,Bazel 用户和规则作者可以:

  • 独立于 Bazel 更新规则。
  • 根据需要更新和自定义规则。

规则集的新位置将是 bazelbuild/rules_androidrules_ccrules_javarules_pythongoogle/protobufrules_proto 即将被弃用。

Bazel 8 将提供一个临时迁移标志,该标志会自动使用之前从其代码库中作为二进制文件一部分的规则集。这些规则集的所有用户最终都应依赖于其代码库,并以与从未纳入 Bazel 的其他规则集类似的方式加载它们。

Bazel 8 还将改进现有的扩展规则和子规则 API,并将其标记为非实验性 API。

Starlark 改进

  • 符号宏是一种编写宏的新方法,对 BUILD 用户、宏作者和工具更友好。与 Bazel 只能有限地了解的旧版宏相比,符号宏可帮助用户避免常见陷阱并强制执行最佳实践。
  • 软件包终结器是一项提议的功能,旨在为自定义软件包验证逻辑添加一流支持。它们旨在帮助我们弃用 native.existing_rules()

可配置性

  • 输出路径映射继续稳定:为使用转换的规则设计师带来更好的远程缓存性能和构建速度。
  • 自动设置适用于给定 --platforms 的 build 标志。
  • 定义项目支持的标志组合,并使用默认标志自动构建目标,而无需设置 bazelrc。
  • 请勿在每次 build 标志发生变化时重新执行 build 分析。

Project Skyfocus - 尽量减少保留的数据结构

Bazel 会在 RAM 中保留大量状态,以便快速进行增量构建。不过,开发者通常只会更改源文件的一小部分(例如,几乎从不更改外部依赖项)。借助 Skyfocus,Bazel 将提供一种实验性方法来丢弃不必要的增量状态并减少 Bazel 的内存占用量,同时仍能提供相同的快速增量构建体验。

初始范围仅旨在改进保留堆指标。峰值堆减小是可能的,但不在初始范围内。

其他

  • Mobile install v3,一种更简单、更易于维护的方法,可增量部署 Android 应用。
  • 对代码库缓存和 Bazel 的 install_base 进行垃圾回收。
  • 减少了沙盒化开销。

Bazel-JetBrains* IntelliJ IDEA 支持

增量 IntelliJ 插件更新,以支持最新的 JetBrains 插件版本。

此路线图仅列出了目标,不应视为保证。这些优先事项可能会根据开发者和客户的反馈或新的市场机遇而发生变化。

如需接收有关新功能(包括此路线图的更新)的通知,请加入 Google 群组社区。

*版权所有 © 2022 JetBrains s.r.o。JetBrains 和 IntelliJ 是 JetBrains s.r.o 的注册商标