Pengantar Bazel

Bazel adalah alat build dan pengujian open source yang mirip dengan Make, Maven, dan Gradle. Class ini menggunakan bahasa build tingkat tinggi yang dapat dibaca manusia. Bazel mendukung project dalam berbagai bahasa dan mem-build output untuk berbagai platform. Bazel mendukung codebase besar di beberapa repositori, dan pengguna dalam jumlah besar.

Manfaat

Bazel menawarkan keuntungan berikut:

  • Bahasa build tingkat tinggi. Bazel menggunakan bahasa abstrak yang dapat dibaca manusia untuk mendeskripsikan properti build project Anda pada tingkat semantik yang tinggi. Tidak seperti alat lainnya, Bazel beroperasi berdasarkan konsep library, biner, skrip, dan set data, sehingga melindungi Anda dari kompleksitas penulisan panggilan individual ke alat seperti compiler dan linker.

  • Bazel cepat dan andal. Bazel menyimpan semua pekerjaan yang telah dilakukan sebelumnya dalam cache dan melacak perubahan pada konten file dan perintah build. Dengan cara ini, Bazel mengetahui kapan ada sesuatu yang perlu dibuat ulang, dan hanya membangun kembali aplikasi tersebut. Untuk lebih mempercepat build, Anda dapat menyiapkan project untuk di-build dengan cara yang sangat paralel dan inkremental.

  • Bazel bersifat multi-platform. Bazel berjalan di Linux, macOS, dan Windows. Bazel dapat mem-build biner dan paket yang dapat di-deploy untuk berbagai platform, termasuk desktop, server, dan seluler, dari project yang sama.

  • Bazel timbangan. Bazel mempertahankan ketangkasan saat menangani build yang berisi lebih dari 100 ribu file sumber. Solusi ini dapat digunakan dengan banyak repositori dan basis pengguna dalam puluhan ribu.

  • Bazel dapat diperluas. Banyak bahasa yang didukung, dan Anda dapat memperluas Bazel agar mendukung bahasa atau framework lainnya.

Menggunakan Bazel

Untuk membangun atau menguji project dengan Bazel, Anda biasanya perlu melakukan hal berikut:

  1. Menyiapkan Bazel. Download dan instal Bazel.

  2. Siapkan project workspace, yang merupakan direktori tempat Bazel mencari input build dan file BUILD, serta tempat menyimpan output build.

  3. Tulis file BUILD, yang memberi tahu Bazel apa yang harus di-build dan cara mem-build-nya.

    Anda menulis file BUILD dengan mendeklarasikan target build menggunakan Starlark, bahasa khusus domain. (Lihat contohnya di sini.)

    Target build menentukan kumpulan artefak input yang akan di-build oleh Bazel beserta dependensinya, aturan build yang akan digunakan Bazel untuk mem-build-nya, dan opsi yang mengonfigurasi aturan build.

    Aturan build menentukan alat build yang akan digunakan Bazel, seperti compiler dan linker, serta konfigurasinya. Bazel dilengkapi dengan sejumlah aturan build yang mencakup jenis artefak paling umum dalam bahasa yang didukung pada platform yang didukung.

  4. Jalankan Bazel dari command line. Bazel menempatkan output di dalam ruang kerja.

Selain mem-build, Anda juga dapat menggunakan Bazel untuk menjalankan pengujian dan mengkueri build untuk melacak dependensi dalam kode Anda.

Proses build Bazel

Saat menjalankan build atau pengujian, Bazel akan melakukan hal berikut:

  1. Memuat file BUILD yang relevan dengan target.

  2. Menganalisis input dan dependensinya, menerapkan aturan build yang ditentukan, dan menghasilkan grafik tindakan.

  3. Mengeksekusi tindakan build pada input hingga output build akhir dihasilkan.

Karena semua tugas build sebelumnya di-cache, Bazel dapat mengidentifikasi dan menggunakan kembali artefak yang di-cache dan hanya mem-build ulang atau menguji ulang apa yang berubah. Untuk meningkatkan ketepatan lebih lanjut, Anda dapat menyiapkan Bazel untuk menjalankan build dan pengujian secara hermetis melalui sandboxing, meminimalkan kecondongan dan memaksimalkan reproduksibilitas.

Grafik tindakan

Grafik tindakan merepresentasikan artefak build, hubungan di antara keduanya, dan tindakan build yang akan dilakukan Bazel. Berkat grafik ini, Bazel dapat melacak perubahan pada konten file serta perubahan pada tindakan, seperti perintah build atau pengujian, dan mengetahui tugas build yang telah dilakukan sebelumnya. Grafik ini juga memungkinkan Anda melacak dependensi dengan mudah dalam kode Anda.

Tutorial memulai

Untuk mulai menggunakan Bazel, lihat Memulai atau langsung buka tutorial Bazel: