Primeiros passos com o contêiner do Docker do Bazel

Informar um problema Ver código-fonte Nightly · 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

Esta página fornece detalhes sobre o conteúdo do contêiner do Bazel, como criar o projeto abseil-cpp usando o Bazel dentro do contêiner do Bazel e como criar esse projeto diretamente na máquina host usando o contêiner do Bazel com montagem de diretório.

Criar um projeto Abseil na máquina host com montagem de diretório

As instruções desta seção permitem que você crie usando o contêiner do Bazel com as origens extraídas no ambiente de host. Um contêiner é iniciado para cada comando de build executado. Os resultados do build são armazenados em cache no ambiente do host para que possam ser reutilizados em builds.

Clone o projeto para um diretório na máquina host.

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

Crie uma pasta que terá resultados armazenados em cache para serem compartilhados entre as builds.

mkdir -p /tmp/build_output/

Use o contêiner do Bazel para criar o projeto e disponibilizar as saídas do build na pasta de saída da máquina host.

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/...

Crie o projeto com limpadores adicionando a flag de build --config=asan|tsan|msan para selecionar o AddressSanitizer (asan), o ThreadSanitizer (tsan) ou o MemorySanitizer (msan) de acordo.

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

Criar o projeto Abseil dentro do contêiner

As instruções nesta seção permitem que você crie usando o contêiner do Bazel com as origens dentro do contêiner. Ao iniciar um contêiner no início do fluxo de trabalho de desenvolvimento e fazer alterações no espaço de trabalho dentro do contêiner, os resultados de build serão armazenados em cache.

Inicie um shell no contêiner do Bazel:

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

Cada ID de contêiner é único. Nas instruções abaixo, o contêiner era 5a99103747c6.

Clone o projeto.

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

Faça um build regular.

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

Crie o projeto com limpadores adicionando a flag de build --config=asan|tsan|msan para selecionar AddressSanitizer (asan), ThreadSanitizer (tsan) ou MemorySanitizer (msan).

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

Conheça o contêiner do Bazel

Se ainda não fez isso, inicie um shell interativo dentro do contêiner do Bazel.

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

Confira o conteúdo do contêiner.

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

Conheça o Dockerfile do Bazel

Para conferir como a imagem do Docker do Bazel é criada, acesse o Dockerfile em bazelbuild/continuous-integration/bazel/oci.