Introdução ao Bazel

O Bazel é uma ferramenta de build e teste de código aberto semelhante ao Make, Maven e Gradle. Ele usa uma linguagem de build legível e de alto nível. Ele oferece suporte a projetos em várias linguagens e cria saídas para várias plataformas. Ele é compatível com grandes bases de código em vários repositórios e em um grande número de usuários.

Vantagens

Ele oferece as seguintes vantagens:

  • Linguagem de build de alto nível. Ele usa uma linguagem abstrata e legível para descrever as propriedades de build do projeto em um alto nível semântico. Ao contrário de outras ferramentas, ele opera com base nos conceitos de bibliotecas, binários, scripts e conjuntos de dados, protegendo você da complexidade de escrever chamadas individuais para ferramentas como compiladores e vinculadores.

  • O Bazel é rápido e confiável. Ele armazena em cache todo o trabalho concluído e rastreia as mudanças no conteúdo do arquivo e nos comandos de build. Dessa forma, o Bazel sabe quando algo precisa ser recriado e recria apenas isso. Para acelerar ainda mais seus builds, configure seu projeto para criar de maneira altamente paralela e incremental.

  • O Bazel é multiplataforma. O Bazel é executado no Linux, macOS e Windows. Ele pode criar binários e pacotes implantáveis para várias plataformas, incluindo computador, servidor e dispositivos móveis, a partir do mesmo projeto.

  • O Bazel é escalonado. O Bazel mantém a agilidade ao processar builds com mais de 100 mil arquivos de origem. Ele funciona com vários repositórios e bases de usuários em dezenas de milhares.

  • O Bazel é extensível. Muitas linguagens são compatíveis, e você pode estender o Bazel a qualquer outra linguagem ou framework.

Como usar o Bazel

Para criar ou testar um projeto com o Bazel, faça o seguinte:

  1. Configure o Bazel. Faça o download e instale o Bazel.

  2. Configure um espaço de trabalho do projeto, que é um diretório em que o Bazel procura entradas de build e arquivos BUILD e armazena saídas de build.

  3. Escreva um arquivo BUILD, que informe ao Bazel o que e como compilar.

    Escreva o arquivo BUILD declarando destinos de build usando Starlark, uma linguagem específica de domínio. Veja um exemplo aqui.

    Um destino de build especifica um conjunto de artefatos de entrada que o Bazel vai criar, além das respectivas dependências, a regra de build que o Bazel vai usar para isso e as opções que configuram essa regra.

    Uma regra de build especifica as ferramentas de build que o Bazel vai usar, como compiladores e vinculadores, e as respectivas configurações. Ele é enviado com várias regras de build que abrangem os tipos de artefato mais comuns nas linguagens com suporte nas plataformas com suporte.

  4. Execute o Bazel na linha de comando. O Bazel coloca as saídas no espaço de trabalho.

Além de compilar, também é possível usar o Bazel para executar testes e consultar o build para rastrear dependências no código.

Processo de compilação do Bazel

Ao executar uma versão ou um teste, o Bazel faz o seguinte:

  1. Carrega os arquivos BUILD relevantes para o destino.

  2. Analisa as entradas e as dependências delas, aplica as regras de build especificadas e produz um gráfico de ações.

  3. Execute as ações de build nas entradas até que as saídas finais da build sejam produzidas.

Como todo o trabalho de build anterior está armazenado em cache, o Bazel pode identificar e reutilizar artefatos armazenados em cache e apenas recriar ou testar novamente o que mudou. Para aplicar ainda mais a correção, é possível configurar o Bazel para executar builds e testes hermeticamente usando o sandbox, minimizando o desvio e maximizando a reprodutibilidade.

Gráfico de ações

O gráfico de ações representa os artefatos de build, as relações entre eles e as ações que o Bazel vai executar. Graças a esse gráfico, o Bazel pode rastrear mudanças no conteúdo do arquivo, bem como mudanças nas ações, como comandos de build ou teste, e saber qual trabalho de build foi feito anteriormente. O gráfico também permite rastrear dependências no seu código com facilidade.

Tutoriais para começar

Para começar a usar o Bazel, consulte Primeiros passos ou vá diretamente para os tutoriais do Bazel: