Introducción a Bazel

Informar un problema Ver fuente

Bazel es una herramienta de compilación y prueba de código abierto similar a Make, Maven y Gradle. Usa un lenguaje de compilación de alto nivel legible por humanos. Bazel admite proyectos en varios lenguajes y compila resultados para varias plataformas. Bazel admite bases de código grandes en varios repositorios y grandes cantidades de usuarios.

Beneficios

Bazel ofrece las siguientes ventajas:

  • Lenguaje de compilación de alto nivel. Bazel usa un lenguaje abstracto y legible para describir las propiedades de compilación de tu proyecto a un alto nivel semántico. A diferencia de otras herramientas, Bazel opera en los conceptos de bibliotecas, objetos binarios, secuencias de comandos y conjuntos de datos, lo que te protege de la complejidad de escribir llamadas individuales a herramientas como compiladores y vinculadores.

  • Bazel es rápido y confiable. Bazel almacena en caché todo el trabajo realizado anteriormente y hace un seguimiento de los cambios en el contenido del archivo y los comandos de compilación. De esta manera, Bazel sabe cuándo se debe reconstruir algo y solo vuelve a compilar eso. Para acelerar aún más las compilaciones, puedes configurar tu proyecto de modo que se compile de forma incremental y paralela.

  • Bazel es multiplataforma. Bazel se ejecuta en Linux, macOS y Windows. Bazel puede compilar objetos binarios y paquetes implementables para varias plataformas, incluidas computadoras, servidores y dispositivos móviles, a partir del mismo proyecto.

  • Bazels escalas. Bazel mantiene la agilidad mientras maneja compilaciones con más de 100,000 archivos de origen. Funciona con varios repositorios y bases de usuarios de decenas de miles.

  • Bazel es extensible. Se admiten muchos lenguajes, y puedes extender Bazel para que sea compatible con cualquier otro lenguaje o framework.

Usa Bazel

Para compilar o probar un proyecto con Bazel, por lo general, debes hacer lo siguiente:

  1. Configura Bazel. Descarga e instala Bazel.

  2. Configura un espacio de trabajo del proyecto, que es un directorio en el que Bazel busca entradas de compilación y archivos BUILD, y dónde almacena resultados de compilación.

  3. Escribe un archivo BUILD, que le indica a Bazel qué compilar y cómo hacerlo.

    Para escribir el archivo BUILD, declara los destinos de compilación con Starlark, un lenguaje específico del dominio. (Consulta un ejemplo aquí).

    Un destino de compilación especifica un conjunto de artefactos de entrada que Bazel compilará, además de sus dependencias, la regla de compilación que Bazel usará para compilarla y las opciones que configuran la regla de compilación.

    Una regla de compilación especifica las herramientas de compilación que usará Bazel, como compiladores y vinculadores, y sus configuraciones. Bazel se envía con varias reglas de compilación que abarcan los tipos de artefactos más comunes en los lenguajes admitidos en las plataformas compatibles.

  4. Ejecuta Bazel desde la línea de comandos. Bazel coloca los resultados dentro del lugar de trabajo.

Además de compilar, también puedes usar Bazel para ejecutar pruebas y consultar la compilación para hacer un seguimiento de las dependencias en tu código.

Proceso de compilación de Bazel

Cuando se ejecuta una compilación o una prueba, Bazel hace lo siguiente:

  1. Carga los archivos BUILD relevantes para el destino.

  2. Analiza las entradas y sus dependencias, aplica las reglas de compilación especificadas y produce un gráfico de acción.

  3. Ejecuta las acciones de compilación en las entradas hasta que se producen los resultados de la compilación final.

Debido a que todo el trabajo de compilación anterior está almacenado en caché, Bazel puede identificar y reutilizar artefactos almacenados en caché y solo volver a compilar o probar los cambios. Si quieres aplicar aún más la corrección, puedes configurar Bazel para que ejecute compilaciones y pruebas de manera hermética a través de la zona de pruebas, lo que minimiza el sesgo y maximiza la reproducibilidad.

Gráfico de acción

El gráfico de acciones representa los artefactos de compilación, las relaciones entre ellos y las acciones de compilación que realizará Bazel. Gracias a este gráfico, Bazel puede hacer un seguimiento de los cambios en el contenido del archivo y en las acciones, como los comandos de compilación o prueba, y saber qué trabajo de compilación se realizó antes. El gráfico también te permite realizar un seguimiento de las dependencias en tu código con facilidad.

Instructivos de introducción

Para comenzar a usar Bazel, consulta Primeros pasos o ve directamente a los instructivos de Bazel: