Bazel Docker 容器使用入门

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

本页详细介绍了 Bazel 容器的内容、如何在 Bazel 容器内使用 Bazel 构建 abseil-cpp 项目,以及如何使用带有目录挂载的 Bazel 容器直接从主机构建此项目。

使用目录挂载从宿主机构建 Abseil 项目

通过本部分中的说明,您可以使用在宿主环境中检出的源代码通过 Bazel 容器进行构建。系统会为您执行的每个构建命令启动一个容器。构建结果会缓存在主机环境中,以便在各个 build 中重复使用。

将项目克隆到宿主机中的某个目录。

git clone --depth 1 --branch 20220623.1 https://github.com/abseil/abseil-cpp.git /src/workspace

创建一个文件夹,用于存放要在各构建之间共享的缓存结果。

mkdir -p /tmp/build_output/

使用 Bazel 容器构建项目,并在主机的输出文件夹中提供构建输出。

docker run \
  -e USER="$(id -u)" \
  -u="$(id -u)" \
  -v /src/workspace:/src/workspace \
  -v /tmp/build_output:/tmp/build_output \
  -w /src/workspace \
  gcr.io/bazel-public/bazel:latest \
  --output_user_root=/tmp/build_output \
  build //absl/...

通过添加 --config=asan|tsan|msan build 标志来选择 AddressSanitizer (asan)、ThreadSanitizer (tsan) 或 MemorySanitizer (msan),从而使用 sanitizer 构建项目。

docker run \
  -e USER="$(id -u)" \
  -u="$(id -u)" \
  -v /src/workspace:/src/workspace \
  -v /tmp/build_output:/tmp/build_output \
  -w /src/workspace \
  gcr.io/bazel-public/bazel:latest \
  --output_user_root=/tmp/build_output \
  build --config={asan | tsan | msan} -- //absl/... -//absl/types:variant_test

从容器内构建 Abseil 项目

通过本部分中的说明,您可以使用 Bazel 容器和容器内的源代码进行构建。通过在开发工作流的开头启动容器,并在容器内的工作区中进行更改,系统会缓存构建结果。

在 Bazel 容器中启动 shell:

docker run --interactive --entrypoint=/bin/bash gcr.io/bazel-public/bazel:latest

每个容器 ID 都是唯一的。在以下说明中,容器为 5a99103747c6。

克隆项目。

ubuntu@5a99103747c6:~$ git clone --depth 1 --branch 20220623.1 https://github.com/abseil/abseil-cpp.git && cd abseil-cpp/

进行常规 build。

ubuntu@5a99103747c6:~/abseil-cpp$ bazel build //absl/...

通过添加 --config=asan|tsan|msan build 标记来选择 AddressSanitizer (asan)、ThreadSanitizer (tsan) 或 MemorySanitizer (msan),从而使用 sanitizer 构建项目。

ubuntu@5a99103747c6:~/abseil-cpp$ bazel build --config={asan | tsan | msan} -- //absl/... -//absl/types:variant_test

探索 Bazel 容器

如果尚未启动,请在 Bazel 容器内启动交互式 shell。

docker run -it --entrypoint=/bin/bash gcr.io/bazel-public/bazel:latest
ubuntu@5a99103747c6:~$

浏览容器内容。

ubuntu@5a99103747c6:~$ gcc --version
gcc (Ubuntu 9.4.0-1ubuntu1~20.04.1) 9.4.0
Copyright (C) 2019 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
ubuntu@5a99103747c6:~$ java -version
openjdk version "1.8.0_362"
OpenJDK Runtime Environment (build 1.8.0_362-8u372-ga~us1-0ubuntu1~20.04-b09)
OpenJDK 64-Bit Server VM (build 25.362-b09, mixed mode)
ubuntu@5a99103747c6:~$ python -V
Python 3.8.10
ubuntu@5a99103747c6:~$ bazel version
WARNING: Invoking Bazel in batch mode since it is not invoked from within a workspace (below a directory having a WORKSPACE file).
Extracting Bazel installation...
Build label: 6.2.1
Build target: bazel-out/k8-opt/bin/src/main/java/com/google/devtools/build/lib/bazel/BazelServer_deploy.jar
Build time: Fri Jun 2 16:59:58 2023 (1685725198)
Build timestamp: 1685725198
Build timestamp as int: 1685725198

探索 Bazel Dockerfile

如果您想了解如何构建 Bazel Docker 映像,可以前往 bazelbuild/continuous-integration/bazel/oci 查看其 Dockerfile。