หน้านี้มีไว้สำหรับเจ้าของและผู้ดูแลที่เก็บกฎ Bazel ซึ่งอธิบายวิธีกำหนดค่าระบบการรวมอย่างต่อเนื่อง (CI) ของ Bazel สำหรับที่เก็บข้อมูลของคุณเพื่อทดสอบความเข้ากันได้ของกฎกับสถานการณ์การเรียกใช้จากระยะไกล วิธีการในหน้านี้ใช้กับโปรเจ็กต์ที่เก็บไว้ในที่เก็บของ GitHub
ข้อกำหนดเบื้องต้น
โปรดตรวจสอบสิ่งต่อไปนี้ก่อนทำตามขั้นตอนในหน้านี้
- ที่เก็บ GitHub เป็นส่วนหนึ่งของ องค์กร Bazel GitHub
- คุณได้กําหนดค่า Buildkite สําหรับที่เก็บข้อมูลตามที่อธิบายไว้ในการผสานรวมอย่างต่อเนื่องของ Bazel
การตั้งค่า Bazel CI สำหรับการทดสอบ
ในไฟล์
.bazelci/presubmit.yml
ให้ทำดังนี้ก. เพิ่มการกําหนดค่าชื่อ
rbe_ubuntu1604
ข. ในการกำหนดค่า
rbe_ubuntu1604
ให้เพิ่มบิลด์และทดสอบเป้าหมายที่ต้องการทดสอบกับการดำเนินการจากระยะไกลเพิ่มที่เก็บ
bazel-toolchains
GitHub ลงในไฟล์WORKSPACE
ซึ่งปักหมุดไว้กับรุ่นล่าสุด และเพิ่มเป้าหมายrbe_autoconfig
ที่มีชื่อว่าbuildkite_config
ด้วย ตัวอย่างนี้สร้างการกำหนดค่า Toolchain สำหรับการดำเนินการระยะไกลด้วย BuildKite CI สำหรับrbe_ubuntu1604
load("@bazel_toolchains//rules:rbe_repo.bzl", "rbe_autoconfig")
rbe_autoconfig(name = "buildkite_config")
ส่งคำขอดึงข้อมูลพร้อมการเปลี่ยนแปลงในไฟล์
presubmit.yml
(ดูตัวอย่างคำขอดึง)หากต้องการดูผลการบิลด์ ให้คลิกรายละเอียดสำหรับการตรวจสอบคำขอดึงข้อมูล RBE (Ubuntu 16.04) ใน GitHub ดังที่แสดงในภาพด้านล่าง โดยลิงก์นี้จะพร้อมใช้งานหลังจากผสานคำขอพุลและทำการทดสอบ CI แล้ว (ดูตัวอย่างผลลัพธ์)
(ไม่บังคับ) ตั้งค่าการตรวจสอบ bazel test (RBE (Ubuntu 16.04)) เป็นการตรวจสอบที่ต้องผ่านก่อนผสานในกฎการป้องกันสาขา การตั้งค่านี้จะอยู่ใน GitHub ในการตั้งค่า > สาขา > กฎการป้องกัน Branch ดังที่แสดงในรูปต่อไปนี้
การแก้ปัญหาการสร้างและการทดสอบที่ล้มเหลว
หากบิลด์หรือการทดสอบไม่สำเร็จ อาจเป็นเพราะสาเหตุต่อไปนี้
ไม่ได้ติดตั้งเครื่องมือสร้างหรือทดสอบที่จำเป็นในคอนเทนเนอร์เริ่มต้น บิลด์โดยใช้การกำหนดค่า
rbe_ubuntu1604
ที่เรียกใช้โดยค่าเริ่มต้นภายในคอนเทนเนอร์rbe-ubuntu16-04
ซึ่งมีเครื่องมือที่ใช้กับบิลด์มากมายของ Bazel อย่างไรก็ตาม หากกฎต้องใช้เครื่องมือที่ไม่มีอยู่ในคอนเทนเนอร์เริ่มต้น คุณต้องสร้างคอนเทนเนอร์ที่กำหนดเองโดยอิงตามคอนเทนเนอร์rbe-ubuntu16-04
และรวมเครื่องมือเหล่านั้นตามที่อธิบายไว้ภายหลังเป้าหมายการสร้างหรือทดสอบใช้กฎที่ใช้ร่วมกับการดําเนินการจากระยะไกลไม่ได้ ดูรายละเอียดเกี่ยวกับความเข้ากันได้กับการดำเนินการระยะไกลได้ที่การปรับกฎ Bazel สําหรับการดําเนินการระยะไกล
การใช้คอนเทนเนอร์ที่กำหนดเองในการกำหนดค่า rbe_ubuntu1604 CI
คอนเทนเนอร์ rbe-ubuntu16-04
พร้อมให้บริการแบบสาธารณะที่ URL ต่อไปนี้
http://gcr.io/cloud-marketplace/google/rbe-ubuntu16-04
คุณสามารถดึงข้อมูลดังกล่าวจาก Container Registry โดยตรงหรือจะสร้างจากแหล่งที่มาก็ได้ ส่วนถัดไปจะอธิบายทั้ง 2 ตัวเลือก
ก่อนเริ่มต้น โปรดตรวจสอบว่าคุณได้ติดตั้ง gcloud
, docker
และ git
แล้ว
หากสร้างคอนเทนเนอร์จากแหล่งที่มา คุณต้องติดตั้ง Bazel เวอร์ชันล่าสุดด้วย
ดึง rbe-ubuntu16-04 จาก Container Registry
หากต้องการดึงข้อมูลคอนเทนเนอร์ rbe-ubuntu16-04
จาก Container Registry ให้เรียกใช้คำสั่งต่อไปนี้
gcloud docker -- pull gcr.io/cloud-marketplace/google/rbe-ubuntu16-04@sha256:sha256-checksum
แทนที่ sha256-checksum ด้วยค่าการตรวจสอบ SHA256 สำหรับคอนเทนเนอร์ล่าสุด
การสร้างคอนเทนเนอร์ rbe-ubuntu16-04 จากซอร์ส
หากต้องการสร้างคอนเทนเนอร์ rbe-ubuntu16-04
จากต้นทาง ให้ทำดังนี้
โคลนที่เก็บ
bazel-toolchains
git clone https://github.com/bazelbuild/bazel-toolchains
ตั้งค่าเป้าหมายคอนเทนเนอร์ของเครื่องมือและสร้างคอนเทนเนอร์ตามที่อธิบายไว้ในคอนเทนเนอร์ของเครื่องมือ
ดึงข้อมูลคอนเทนเนอร์ที่เพิ่งสร้างขึ้น
gcloud docker -- pull gcr.io/project-id/custom-container-namesha256-checksum
เรียกใช้คอนเทนเนอร์ที่กำหนดเอง
หากต้องการเรียกใช้คอนเทนเนอร์ที่กําหนดเอง ให้ทําอย่างใดอย่างหนึ่งต่อไปนี้
ถ้าคุณดึงคอนเทนเนอร์จาก Container Registry ให้เรียกใช้คำสั่งต่อไปนี้
docker run -it gcr.io/cloud-marketplace/google/rbe-ubuntu16-04@sha256:sha256-checksum/bin/bash
แทนที่
sha256-checksum
ด้วยค่าผลรวมตรวจสอบ SHA256 สำหรับคอนเทนเนอร์ล่าสุดหากคุณสร้างคอนเทนเนอร์จากต้นทาง ให้เรียกใช้คำสั่งต่อไปนี้
docker run -it gcr.io/project-id/custom-container-name@sha256:sha256sum /bin/bash
การเพิ่มทรัพยากรลงในคอนเทนเนอร์ที่กำหนดเอง
ใช้ Dockerfile
หรือ
rules_docker
เพื่อเพิ่มทรัพยากรหรือ
ทรัพยากรต้นฉบับเวอร์ชันอื่นลงในคอนเทนเนอร์ rbe-ubuntu16-04
หากคุณเพิ่งเริ่มใช้ Docker โปรดอ่านข้อมูลต่อไปนี้
ตัวอย่างเช่น ข้อมูลโค้ด Dockerfile
ต่อไปนี้จะติดตั้ง my_tool_package
FROM gcr.io/cloud-marketplace/google/rbe-ubuntu16-04@sha256:sha256-checksum
RUN apt-get update && yes | apt-get install -y my_tool_package
พุชคอนเทนเนอร์ที่กำหนดเองไปยัง Container Registry
เมื่อปรับแต่งคอนเทนเนอร์แล้ว ให้สร้างอิมเมจคอนเทนเนอร์และพุชไปยัง Container Registry ดังนี้
สร้างอิมเมจคอนเทนเนอร์โดยใช้คำสั่งต่อไปนี้
docker build -t custom-container-name.
docker tag custom-container-name gcr.io/project-id/custom-container-name
พุชอิมเมจคอนเทนเนอร์ไปยัง Container Registry ด้วยคำสั่งต่อไปนี้
gcloud docker -- push gcr.io/project-id/custom-container-name
ไปที่ URL ต่อไปนี้เพื่อยืนยันว่ามีการพุชคอนเทนเนอร์แล้ว
https://console.cloud.google.com/gcr/images/project-id/GLOBAL/custom-container-name
จดผลรวมตรวจสอบ SHA256 ของคอนเทนเนอร์ที่กำหนดเอง คุณจะต้องระบุข้อมูลดังกล่าวในคำจำกัดความของแพลตฟอร์มบิลด์ในภายหลัง
กำหนดค่าคอนเทนเนอร์สำหรับการเข้าถึงแบบสาธารณะตามที่อธิบายไว้ในการเข้าถึงแบบสาธารณะ
สำหรับข้อมูลเพิ่มเติม โปรดดู การดันและดึงรูปภาพ
การระบุคําจํากัดความของแพลตฟอร์มการสร้าง
คุณต้องใส่การกําหนดค่าแพลตฟอร์ม Bazel ในการกําหนดค่าเครื่องมือทํางานที่กำหนดเอง ซึ่งจะช่วยให้ Bazel เลือกเครื่องมือทํางานที่เหมาะกับแพลตฟอร์มฮาร์ดแวร์/ซอฟต์แวร์ที่ต้องการได้ หากต้องการสร้างแพลตฟอร์มที่ถูกต้องโดยอัตโนมัติ คุณสามารถเพิ่มเป้าหมาย WORKSPACE
rbe_autoconfig
ที่มีชื่อ buildkite_config
ลงใน WORKSPACE
ซึ่งมีแอตทริบิวต์เพิ่มเติมเพื่อเลือกคอนเทนเนอร์ที่กำหนดเอง โปรดอ่านรายละเอียดเกี่ยวกับการตั้งค่านี้จากเอกสารประกอบล่าสุดสําหรับ rbe_autoconfig