谷歌构建工具 Bazel 现在开源了

阅读数:4235 2015 年 3 月 30 日

话题:开源Google语言 & 开发架构文化 & 方法

Bazel,谷歌用来构建大多数软件的工具,现在已经部分开源了。谷歌声称,Bazel 的目标是构建“快速并可靠的代码”,并且能“随着公司的成长持续调整其软件开发实践”。

在 Bazel 之前,谷歌使用的软件构建工具是 Makefiles。它往往过于厚重,结果形成了“缓慢且不可靠的构建”。此外,与 Makefiles 相比,Bazel 还提供了更高层次的概念,比如“Java 测试”、“C++ 库”,以及“目标平台”和“主机平台”等等。

这个层次的概念是由 BUILD提供的,它是一种“把项目描述成一组小的有关联的类库、二进制文件和测试”的语言。可以看看以下示例简单地了解一下 BUILD 文件的写法:

package(default_visibility = [“//visibility:public”])

cc_library(
  name = "hello-lib",
  srcs = ["hello-lib.cc"],
  hdrs = ["hello-lib.h"],
)

cc_binary(
  name = "hello-world",
  srcs = ["hello-world.cc"],
  deps = [":hello-lib"],
)

cc_test(
  name = "hello-success_test",
  srcs = ["hello-world.cc"],
  deps = [":hello-lib"],
)

Bazel 能够带来很多的好处,谷歌特别强烈了其中的两点:

  • 效率,这要得益于它实际上只重新编译那些必要的文件,也会跳过那些不必去执行的测试。
  • 结果的重现,确保无论是“增量还是重新完整构建、笔记本电脑还是持续集成系统”结果都不会有偏差。

为了满足谷歌自己的需求,Bazel 可以成为具有任意组合特征的项目的特定套件,这些特征包括:具有大型的、共享的数据库;支持多个平台;以多种语言写成;具有大量的测试套件等。

值得一提的是,Bazel 将不会完全地开源。的确是这样,谷歌声称,“我们有大量代码未开源;按规则来算,此时此刻只开源了 10% 吧。”谷歌将实施如此的政策是发现了这么一种情况,那就是核心贡献者组织会积极地投身于 Bazel,而“外围贡献者对项目的支持比较有限,只会贡献一些零零散散的变更。”

InfoQ 与 Bazel 的核心贡献者组织取得了联系,向他们了解以下相关的问题,使用 Bazel 预计会得到怎样的速度提升?与近来其他的竞争对手(比如 Facebook 的 Buck 和 Pants)相比,你们未来会提供哪些与众不同的特性吗?在他们回应之后我们将发出后续的报道。

Bazel 可以运行于基于 Linux 的系统和 OS X,但它目前尚未不支持 Windows,而且谷歌“现在尚未打算为此投入力量”,直到它成为主要目标为止。

查看英文原文Bazel: Google Build Tool is now Open Source