Bazel Docker कंटेनर का इस्तेमाल शुरू करना

किसी समस्या की शिकायत करें सोर्स देखें Nightly · 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

इस पेज पर, Bazel कंटेनर के कॉन्टेंट के बारे में जानकारी दी गई है. साथ ही, Bazel कंटेनर में Bazel का इस्तेमाल करके, abseil-cpp प्रोजेक्ट को बनाने का तरीका बताया गया है. इसके अलावा, डायरेक्ट्री माउंट करने के साथ Bazel कंटेनर का इस्तेमाल करके, सीधे होस्ट मशीन से इस प्रोजेक्ट को बनाने का तरीका भी बताया गया है.

डायरेक्ट्री माउंटिंग की मदद से, अपनी होस्ट मशीन से Abseil प्रोजेक्ट बनाएं

इस सेक्शन में दिए गए निर्देशों की मदद से, अपने होस्ट एनवायरमेंट में चेक आउट किए गए सोर्स के साथ, Basel कंटेनर का इस्तेमाल किया जा सकता है. आपके एक्ज़ीक्यूट किए गए हर बिल्ड कमांड के लिए एक कंटेनर शुरू हो जाता है. बिल्ड के नतीजे आपके होस्ट एनवायरमेंट में कैश मेमोरी में सेव किए जाते हैं, ताकि उन्हें सभी बिल्ड में फिर से इस्तेमाल किया जा सके.

प्रोजेक्ट को अपनी होस्ट मशीन की किसी डायरेक्ट्री में क्लोन करें.

git clone https://github.com/abseil/abseil-cpp.git /src/workspace

ऐसा फ़ोल्डर बनाएं जिसमें कैश मेमोरी में सेव किए गए नतीजे, सभी बिल्ड के साथ शेयर किए जा सकेंगे.

mkdir -p /tmp/build_output/

प्रोजेक्ट बनाने के लिए Bazel कंटेनर का इस्तेमाल करें और अपनी होस्ट मशीन के आउटपुट फ़ोल्डर में, बिल्ड आउटपुट उपलब्ध कराएं.

docker run \
  -e USER="$(id -u)" \
  -u="$(id -u)" \
  -v /src/workspace:/src/workspace \
  -v /tmp/build_output:/tmp/build_output \
  -w /src/workspace \
  gcr.io/bazel-public/bazel:latest \
  --output_user_root=/tmp/build_output \
  build //absl/...

सैनिटाइज़र की मदद से प्रोजेक्ट बनाएं. इसके लिए, AddressSanitizer (asan), ThreadSanitizer (tsan) या MemorySanitizer (msan) को चुनने के लिए, --config=asan|tsan|msan बिल्ड फ़्लैग को जोड़ें.

docker run \
  -e USER="$(id -u)" \
  -u="$(id -u)" \
  -v /src/workspace:/src/workspace \
  -v /tmp/build_output:/tmp/build_output \
  -w /src/workspace \
  gcr.io/bazel-public/bazel:latest \
  --output_user_root=/tmp/build_output \
  build --config={asan | tsan | msan} -- //absl/... -//absl/types:variant_test

कंटेनर के अंदर से Abseil प्रोजेक्ट बनाएं

इस सेक्शन में दिए गए निर्देशों की मदद से, कंटेनर के अंदर के सोर्स के साथ Basel कंटेनर का इस्तेमाल किया जा सकता है. डेवलपमेंट वर्कफ़्लो की शुरुआत में कंटेनर शुरू करके और कंटेनर में वर्कस्पेस में बदलाव करके, बिल्ड के नतीजे कैश मेमोरी में सेव हो जाएंगे.

Bazel कंटेनर में शेल शुरू करने के लिए:

docker run --interactive --entrypoint=/bin/bash gcr.io/bazel-public/bazel:latest

हर कंटेनर आईडी यूनीक होता है. नीचे दिए गए निर्देशों में, कंटेनर का नाम 5a99103747c6 था.

प्रोजेक्ट का क्लोन बनाएं.

root@5a99103747c6:~# git clone https://github.com/abseil/abseil-cpp.git && cd abseil-cpp/

नियमित तौर पर बिल्ड करें.

root@5a99103747c6:~/abseil-cpp# bazel build //absl/...

सैनिटाइज़र की मदद से प्रोजेक्ट बनाएं. इसके लिए, पते के हिसाब से AddressSanitizer (asan), ThreadSanitizer (tsan) या MemorySanitizer (msan) को चुनने के लिए, --config=asan|tsan|msanbuild फ़्लैग जोड़ें.

root@5a99103747c6:~/abseil-cpp# bazel build --config=--config={asan | tsan | msan} -- //absl/... -//absl/types:variant_test

Bazel कंटेनर के बारे में जानकारी

अगर आपने पहले से ऐसा नहीं किया है, तो बेज़ल कंटेनर के अंदर एक इंटरैक्टिव शेल शुरू करें.

docker run -it --entrypoint=/bin/bash gcr.io/bazel-public/bazel:latest
root@5a99103747c6:/#

कंटेनर के कॉन्टेंट को एक्सप्लोर करें.

root@5a99103747c6:/# clang --version
clang version 8.0.0 (trunk 340178)
Target: x86_64-unknown-linux-gnu
Thread model: posix
InstalledDir: /usr/local/bin
root@5a99103747c6:/# java -version
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-8u181-b13-0ubuntu0.16.04.1-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)
root@5a99103747c6:/# python -V
Python 2.7.12
root@5a99103747c6:/# python3 -V
Python 3.6.6
root@5a99103747c6:/# bazel version
Extracting Bazel installation...
Build label: 6.0.0
Build target: bazel-out/k8-opt/bin/src/main/java/com/google/devtools/build/lib/bazel/BazelServer_deploy.jar
Build time: Mon Dec 19 15:52:35 2022 (1671465155)
Build timestamp: 1671465155
Build timestamp as int: 1671465155