Halaman ini menjelaskan cara menginstal Bazel dari sumber dan memberikan tips pemecahan masalah untuk masalah umum.
Untuk mem-build Bazel dari sumber, Anda dapat melakukan salah satu langkah berikut:
Bangun aplikasi tersebut menggunakan biner Bazel yang sudah ada
Bangun aplikasi tersebut tanpa biner Bazel yang ada yang dikenal sebagai bootstrap.
Membuat Bazel menggunakan Bazel
Ringkasan
Dapatkan rilis Bazel terbaru dari halaman rilis GitHub atau dengan Bazelisk.
Download sumber Bazel dari GitHub dan ekstrak di suatu tempat. Atau, Anda dapat meng-clone hierarki sumber dari https://github.com/bazelbuild/bazel
Instal prasyarat yang sama seperti untuk bootstrap (lihat untuk sistem mirip Unix atau untuk Windows)
Build build pengembangan Bazel menggunakan Bazel:
bazel build //src:bazel-dev
(ataubazel build //src:bazel-dev.exe
di Windows)Biner yang dihasilkan ada di
bazel-bin/src/bazel-dev
(ataubazel-bin\src\bazel-dev.exe
di Windows). Anda dapat menyalinnya ke mana saja dan langsung menggunakannya tanpa penginstalan lebih lanjut.
Petunjuk detailnya ikuti di bawah ini.
Langkah 1: Dapatkan rilis Bazel terbaru
Sasaran: Menginstal atau mendownload Bazel versi rilis. Pastikan Anda dapat menjalankannya
dengan mengetikkan bazel
di terminal.
Alasan: Untuk mem-build Bazel dari hierarki sumber GitHub, Anda memerlukan biner Bazel yang sudah ada. Anda dapat menginstalnya dari pengelola paket atau mendownloadnya dari GitHub. Lihat Menginstal Bazel. (Atau, Anda dapat membangun dari awal (bootstrap).)
Pemecahan masalah:
Jika Anda tidak dapat menjalankan Bazel dengan mengetik
bazel
di terminal:Mungkin direktori biner Bazel Anda tidak ada dalam PATH.
Hal ini bukan masalah besar. Anda harus mengetik jalur lengkap, bukan mengetik
bazel
.Mungkin biner Bazel itu sendiri tidak disebut
bazel
(di Unix) ataubazel.exe
(di Windows).Hal ini bukan masalah besar. Anda dapat mengganti nama biner, atau mengetik nama biner, bukan
bazel
.Mungkin biner tidak dapat dieksekusi (pada Unix).
Anda harus menjadikan biner sebagai file yang dapat dieksekusi dengan menjalankan
chmod +x /path/to/bazel
.
Langkah 2: Download sumber Bazel dari GitHub
Jika Anda terbiasa dengan Git, cukup git clone https://github.com/bazelbuild/bazel
Atau:
Download sumber terbaru sebagai file zip.
Ekstrak konten di suatu tempat.
Misalnya, buat direktori
bazel-src
di direktori utama Anda dan ekstrak di sana.
Langkah 3: Instal prasyarat
Instal prasyarat yang sama seperti untuk bootstrap (lihat di bawah) -- JDK, compiler C++, MSYS2 (jika Anda membangun di Windows), dll.
Langkah 4a: Mem-build Bazel di Ubuntu Linux, macOS, dan sistem mirip Unix lainnya
Guna mengetahui petunjuk untuk Windows, lihat Membuat Bazel di Windows.
Sasaran: Jalankan Bazel untuk mem-build biner Bazel kustom (bazel-bin/src/bazel-dev
).
Petunjuk:
Memulai terminal Bash
cd
ke dalam direktori tempat Anda mengekstrak (atau meng-clone) sumber Bazel.Misalnya, jika Anda mengekstrak sumber yang ada di direktori utama, jalankan:
cd ~/bazel-src
Buat Bazel dari sumber:
bazel build //src:bazel-dev
Atau, Anda dapat menjalankan
bazel build //src:bazel --compilation_mode=opt
untuk menghasilkan biner yang lebih kecil, tetapi proses build-nya lebih lambat.Output-nya akan berada di
bazel-bin/src/bazel-dev
(ataubazel-bin/src/bazel
).
Langkah 4b: Bangun Bazel di Windows
Untuk mengetahui petunjuk pada sistem yang mirip dengan Unix, lihat Ubuntu Linux, macOS, dan sistem lain yang serupa dengan Unix.
Sasaran: Jalankan Bazel untuk membuat biner Bazel kustom
(bazel-bin\src\bazel-dev.exe
).
Petunjuk:
Memulai Command Prompt (Start Menu > Run > "cmd.exe")
cd
ke direktori tempat Anda mengekstrak (atau meng-clone) sumber Bazel.Misalnya, jika Anda mengekstrak sumber yang ada di direktori utama, jalankan:
cd %USERPROFILE%\bazel-src
Buat Bazel dari sumber:
bazel build //src:bazel-dev.exe
Atau, Anda dapat menjalankan
bazel build //src:bazel.exe --compilation_mode=opt
untuk menghasilkan biner yang lebih kecil, tetapi lebih lambat untuk di-build.Outputnya akan berada di
bazel-bin\src\bazel-dev.exe
(ataubazel-bin\src\bazel.exe
).
Langkah 5: Instal biner yang di-build
Sebenarnya, tidak ada yang perlu diinstal.
Output dari langkah sebelumnya adalah biner Bazel mandiri. Anda dapat menyalinnya ke direktori mana pun dan langsung menggunakannya. (Akan berguna jika direktori tersebut ada dalam JALUR Anda sehingga Anda dapat menjalankan "bazel" di mana saja.)
Mem-build Bazel dari awal (bootstrapping)
Anda juga bisa membangun Bazel dari awal, tanpa menggunakan biner Bazel yang sudah ada.
Langkah 1: Download sumber Bazel (arsip distribusi)
(Langkah ini sama untuk semua platform.)
Download
bazel-<version>-dist.zip
dari GitHub, misalnyabazel-0.28.1-dist.zip
.Perhatian:
- Ada arsip distribusi tunggal yang tidak bergantung pada arsitektur. Tidak ada arsip distribusi khusus arsitektur atau OS tertentu.
- Sumber ini tidak sama dengan struktur sumber GitHub. Anda harus menggunakan arsip distribusi untuk melakukan bootstrap pada Bazel. Anda tidak dapat menggunakan hierarki sumber yang di-clone dari GitHub. (Arsip distribusi berisi file sumber yang dihasilkan yang diperlukan untuk bootstrap dan bukan bagian dari hierarki sumber Git normal.)
Ekstrak arsip distribusi di suatu tempat dalam {i>disk<i}.
Anda harus memverifikasi tanda tangan yang dibuat oleh tombol rilis 3D5919B448457EE0 Bazel.
Langkah 2a: Bootstrap Bazel di Ubuntu Linux, macOS, dan sistem mirip Unix lainnya
Untuk mengetahui petunjuk untuk Windows, lihat Bootstrap Bazel di Windows.
2.1. Menginstal prasyarat
Bash
zip, ekstrak
Toolchain build C++
JDK. Versi 21 diperlukan.
Python. Versi 2 dan 3 didukung, menginstal salah satunya sudah cukup.
Misalnya, di Ubuntu Linux, Anda dapat menginstal persyaratan ini menggunakan perintah berikut:
sudo apt-get install build-essential openjdk-21-jdk python zip unzip
2.2. Melakukan bootstrap Bazel di Unix
Buka jendela shell atau Terminal.
cd
ke direktori tempat Anda mengekstrak arsip distribusi.Jalankan skrip kompilasi:
env EXTRA_BAZEL_ARGS="--tool_java_runtime_version=local_jdk" bash ./compile.sh
.
Output yang dikompilasi ditempatkan ke dalam output/bazel
. Ini adalah biner Bazel
mandiri, tanpa JDK tersemat. Anda dapat menyalinnya ke mana saja atau menggunakannya
di tempat. Untuk memudahkan, salin biner ini ke direktori yang ada di
PATH
Anda (seperti /usr/local/bin
di Linux).
Untuk mem-build biner bazel
dengan cara yang dapat direproduksi, tetapkan juga
SOURCE_DATE_EPOCH
di langkah "Jalankan skrip kompilasi".
Langkah 2b: Bootstrap Bazel di Windows
Untuk petunjuk sistem yang mirip Unix, lihat Mem-bootstrap Bazel di Ubuntu Linux, macOS, dan sistem mirip Unix lainnya.
2.1. Instal prasyarat
Paket MSYS2 untuk zip dan ekstrak. Jalankan perintah berikut di shell MSYS2:
pacman -S zip unzip patch
Compiler Visual C++. Instal compiler Visual C++ sebagai bagian dari Visual Studio 2015 atau yang lebih baru, atau dengan menginstal Build Tools untuk Visual Studio 2017 terbaru.
JDK. Versi 21 diperlukan.
Python. Versi 2 dan 3 didukung, menginstal salah satunya sudah cukup. Anda memerlukan versi native Windows (dapat didownload dari https://www.python.org). Versi yang diinstal melalui pacman di MSYS2 tidak akan berfungsi.
2.2. Bazel Bootstrap di Windows
Buka shell MSYS2.
Tetapkan variabel lingkungan berikut:
BAZEL_VS
atauBAZEL_VC
(tidak sama): Tetapkan ke jalur ke direktori Visual Studio (BAZEL_VS) atau ke direktori Visual C++ (BAZEL_VC). Menetapkan salah satunya sudah cukup.BAZEL_SH
: Jalur MSYS2bash.exe
. Lihat perintah dalam contoh di bawah ini.Jangan tetapkan ke
C:\Windows\System32\bash.exe
. (Anda memiliki file tersebut jika Anda menginstal Windows Subsystem untuk Linux.) Bazel tidak mendukung versibash.exe
ini.PATH
: Menambahkan direktori Python.JAVA_HOME
: Tetapkan ke direktori JDK.
Contoh (menggunakan BAZEL_VS):
export BAZEL_VS="C:/Program Files (x86)/Microsoft Visual Studio/2017/BuildTools" export BAZEL_SH="$(cygpath -m $(realpath $(which bash)))" export PATH="/c/python27:$PATH" export JAVA_HOME="C:/Program Files/Java/jdk-21"
atau (menggunakan BAZEL_VC):
export BAZEL_VC="C:/Program Files (x86)/Microsoft Visual Studio/2017/BuildTools/VC" export BAZEL_SH="$(cygpath -m $(realpath $(which bash)))" export PATH="/c/python27:$PATH" export JAVA_HOME="C:/Program Files/Java/jdk-21"
cd
ke direktori tempat Anda mengekstrak arsip distribusi.Jalankan skrip kompilasi:
env EXTRA_BAZEL_ARGS="--tool_java_runtime_version=local_jdk" ./compile.sh
Output yang dikompilasi ditempatkan ke dalam output/bazel.exe
. Ini adalah biner
Bazel mandiri, tanpa JDK tersemat. Anda dapat menyalinnya di mana saja atau
menggunakannya di tempat. Untuk memudahkan, salin biner ini ke direktori yang ada di
PATH
Anda.
Untuk mem-build biner bazel.exe
dengan cara yang dapat direproduksi, tetapkan juga
SOURCE_DATE_EPOCH
pada langkah "Jalankan skrip kompilasi".
Anda tidak perlu menjalankan Bazel dari shell MSYS2. Anda dapat menjalankan Bazel dari
Command Prompt (cmd.exe
) atau PowerShell.