Introducción a Bazel

Bazel es una herramienta de compilación y prueba de código abierto similar a Make, Maven y Gradle. Utiliza un lenguaje de compilación legible y de alto nivel. 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 por humanos para describir las propiedades de compilación de tu proyecto a un alto nivel de semántica. A diferencia de otras herramientas, Bazel opera en 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 compilarlo. Para acelerar aún más tus compilaciones, puedes configurar tu proyecto de manera 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 de escritorio, servidores y dispositivos móviles, desde el mismo proyecto.

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

  • Bazel es extensible. Se admiten muchos lenguajes, y puedes extender Bazel para admitir cualquier otro lenguaje o framework.

Usa Bazel

Para compilar o probar un proyecto con Bazel, sueles hacer lo siguiente:

  1. Configura Bazel. Descarga y, luego, instala Bazel.

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

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

    Para escribir tu 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á junto con sus dependencias, la regla de compilación que Bazel usará para compilarla y las opciones que la configura.

    Una regla de compilación especifica las herramientas de compilación que usará Bazel, como compiladores y vinculadores, y sus parámetros de configuración. Bazel se envía con una serie de 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 a fin de hacer un seguimiento de las dependencias en tu código.

Proceso de compilación de Bazel

Cuando ejecutas 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 acciones.

  3. Ejecuta las acciones de compilación en las entradas hasta que se producen las salidas de compilación finales.

Dado que todo el trabajo de compilación anterior se almacena en caché, Bazel puede identificar y reutilizar artefactos almacenados en caché y solo volver a compilar o probar lo que cambió. Para aplicar más la corrección, puedes configurar Bazel para que ejecute compilaciones y pruebas de forma hermética mediante la zona de pruebas, lo que minimiza el sesgo y maximiza la reproducibilidad.

Gráfico de acción

El gráfico de acción 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 los cambios en 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 con facilidad en tu código.

Instructivos para comenzar

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