แผนกลยุทธ์ของ Bazel

ภาพรวม

เนื่องจากโปรเจ็กต์ Bazel มีการพัฒนาอย่างต่อเนื่องเพื่อตอบสนองความต้องการของคุณ เราจึงอยากแชร์ข้อมูลอัปเดตปี 2024

โรดแมปนี้อธิบายความคิดริเริ่มปัจจุบันและการคาดการณ์เกี่ยวกับการพัฒนา Bazel ในอนาคต ซึ่งจะช่วยให้คุณเห็นภาพลำดับความสำคัญปัจจุบันและโปรเจ็กต์ที่กำลังดำเนินการอยู่

การเผยแพร่ Bazel 8.0

เราวางแผนที่จะเปิดตัวการสนับสนุนระยะยาว long term support (LTS) ของ Bazel 8.0 ในช่วงปลายปี 2024 โดยมีแผนที่จะนำฟีเจอร์ต่อไปนี้มาใช้งาน

Bzlmod: ระบบการจัดการทรัพยากร Dependency ภายนอก

Bzlmod จะแก้ปัญหาทรัพยากร Dependency แบบถ่ายทอดโดยอัตโนมัติ ซึ่งช่วยให้โปรเจ็กต์ขยายขนาดได้โดยยังคงความเร็วและ ประสิทธิภาพด้านทรัพยากรไว้

ใน Bazel 8 เราจะปิดใช้การสนับสนุน WORKSPACE โดยค่าเริ่มต้น (แต่คุณจะยังเปิดใช้ได้โดยใช้ --enable_workspace) และจะนำการสนับสนุน WORKSPACE ออกใน Bazel 9 โดยเริ่มตั้งแต่ Bazel 7.1 คุณสามารถตั้งค่า --noenable_workspace เพื่อเลือกใช้ลักษณะการทำงานใหม่ได้

Bazel 8.0 จะมีการปรับปรุงฟังก์ชันการจัดการทรัพยากร Dependency ภายนอกของ Bazel หลายอย่าง ซึ่งรวมถึง

  • ตั้งค่าแฟล็กใหม่ --enable_workspace เป็น false เพื่อปิดใช้ฟังก์ชัน WORKSPACE โดยสมบูรณ์
  • API การตรวจสอบไดเรกทอรีใหม่ (ดู #21435 ซึ่งเปิดตัวใน Bazel 7.1)
  • ปรับปรุงสคีมาสำหรับการสร้างชื่อที่เก็บข้อมูล Canonical เพื่อให้แคชการดำเนินการได้ดียิ่งขึ้นเมื่อมีการอัปเดตเวอร์ชันทรัพยากร Dependency (#21316 ซึ่งเปิดตัวใน Bazel 7.1)
  • แคชที่เก็บข้อมูลที่ใช้ร่วมกันที่ปรับปรุงแล้ว (ดู #12227)
  • การรองรับโหมดผู้ให้บริการและโหมดออฟไลน์ ซึ่งช่วยให้ผู้ใช้เรียกใช้บิลด์ด้วย ทรัพยากร Dependency ที่ดาวน์โหลดไว้ล่วงหน้าได้ (ดู #19563)
  • ลดความขัดแย้งในการผสานในไฟล์ล็อก (#20396)
  • MODULE.bazel ที่แบ่งเป็นส่วนๆ (#17880)
  • อนุญาตให้ลบล้างที่เก็บข้อมูลที่สร้างโดยส่วนขยายโมดูล (#19301)
  • ปรับปรุงเอกสารประกอบ (เช่น #18030, #15821) รวมถึงคู่มือการย้ายข้อมูลและเครื่องมือการย้ายข้อมูล

การปรับปรุงการดำเนินการจากระยะไกล

  • เพิ่มการรองรับการดำเนินการแบบไม่พร้อมกัน ซึ่งจะช่วยเพิ่มความเร็วในการดำเนินการจากระยะไกลด้วยการเพิ่มการทำงานแบบขนานด้วยแฟล็ก --jobs
  • ทำให้การแก้ไขข้อบกพร่องของแคชที่พลาดง่ายขึ้นด้วยบันทึกการดำเนินการแบบย่อ ซึ่งจะลดขนาดลง 100 เท่าและลดค่าใช้จ่ายในการรันไทม์ลงอย่างมาก (ดู #18643)
  • ใช้ระบบจัดการหน่วยความจำที่ไม่ใช้แล้วสำหรับแคชดิสก์ (ดู #5139)
  • ใช้บริการเอาต์พุตจากระยะไกลเพื่ออนุญาตให้ดาวน์โหลดเอาต์พุตบิลด์ที่กำหนดเองแบบ Lazy (ดู #20933)

การย้ายข้อมูลกฎ Android, C++, Java, Python และ Proto

ย้ายข้อมูลชุดกฎ Android, C++, Java และ Python ไปยังที่เก็บข้อมูลเฉพาะและแยกชุดกฎออกจากรุ่น Bazel ให้เสร็จสมบูรณ์ ซึ่งจะช่วยให้ผู้ใช้ Bazel และผู้เขียนกฎสามารถทำสิ่งต่อไปนี้ได้

  • อัปเดตกฎแยกจาก Bazel
  • อัปเดตและปรับแต่งกฎตามต้องการ

ชุดกฎใหม่จะอยู่ใน bazelbuild/rules_android, rules_cc, rules_java, rules_python และ google/protobuf ส่วน rules_proto จะถูกเลิกใช้งาน

Bazel 8 จะมีแฟล็กการย้ายข้อมูลชั่วคราวที่จะใช้ชุดกฎที่เคยเป็นส่วนหนึ่งของไบนารีจากที่เก็บข้อมูลโดยอัตโนมัติ ผู้ใช้ชุดกฎดังกล่าวทั้งหมดจะต้องใช้ที่เก็บข้อมูลและโหลดชุดกฎในลักษณะเดียวกับชุดกฎอื่นๆ ที่ไม่เคยเป็นส่วนหนึ่งของ Bazel

นอกจากนี้ Bazel 8 จะปรับปรุงกฎการขยายที่มีอยู่และ API กฎย่อย รวมถึงทำเครื่องหมายกฎเหล่านั้นว่าไม่ใช่กฎทดลอง

การปรับปรุง Starlark

  • Symbolic Macro เป็นวิธีใหม่ในการเขียนมาโครที่ใช้งานง่ายสำหรับผู้ใช้ BUILD ผู้เขียนมาโคร และเครื่องมือ เมื่อเทียบกับมาโครเดิมที่ Bazel มีข้อมูลเชิงลึกที่จำกัด Symbolic Macro จะช่วยให้ผู้ใช้หลีกเลี่ยงข้อผิดพลาดทั่วไปและบังคับใช้แนวทางปฏิบัติแนะนำได้
  • Package Finalizer เป็นฟีเจอร์ที่เสนอให้เพิ่มการรองรับตรรกะการตรวจสอบแพ็กเกจที่กำหนดเองระดับเฟิร์สคลาส โดยมีจุดประสงค์เพื่อช่วยให้เราเลิกใช้งาน native.existing_rules()

การกำหนดค่า

  • การแมปเส้นทางเอาต์พุตยังคงมีเสถียรภาพ ซึ่งจะช่วยปรับปรุงประสิทธิภาพของแคชจากระยะไกลและความเร็วในการบิลด์สำหรับผู้ออกแบบกฎที่ใช้การเปลี่ยนสถานะ
  • ตั้งค่าแฟล็กบิลด์ที่เหมาะกับ --platforms ที่ระบุโดยอัตโนมัติ
  • กำหนดชุดค่าผสมของแฟล็กที่โปรเจ็กต์รองรับและสร้างเป้าหมายโดยอัตโนมัติด้วยแฟล็กเริ่มต้นโดยไม่ต้องตั้งค่า bazelrc
  • ไม่ต้องวิเคราะห์บิลด์ใหม่ทุกครั้งที่แฟล็กบิลด์มีการเปลี่ยนแปลง

โปรเจ็กต์ Skyfocus - ลดโครงสร้างข้อมูลที่เก็บไว้

Bazel เก็บสถานะจำนวนมากไว้ใน RAM เพื่อให้บิลด์แบบเพิ่มทำงานได้รวดเร็ว อย่างไรก็ตาม นักพัฒนาซอฟต์แวร์มักจะเปลี่ยนไฟล์ต้นฉบับเพียงส่วนเล็กๆ (เช่น แทบจะไม่เปลี่ยนทรัพยากร Dependency ภายนอกเลย) Skyfocus จะช่วยให้ Bazel มีวิธีทดลองในการทิ้งสถานะแบบเพิ่มที่ไม่จำเป็นและลดการใช้หน่วยความจำของ Bazel โดยที่ยังคงมอบประสบการณ์การใช้งานบิลด์แบบเพิ่มที่รวดเร็วเหมือนเดิม

ขอบเขตเริ่มต้นมีเป้าหมายเพื่อปรับปรุงเมตริกฮีปที่เก็บไว้เท่านั้น การลดฮีปสูงสุดอาจเป็นไปได้ แต่ไม่ได้รวมอยู่ในขอบเขตเริ่มต้น

อื่นๆ

  • การติดตั้งบนอุปกรณ์เคลื่อนที่ v3 ซึ่งเป็นแนวทางที่ง่ายกว่าและมีการดูแลรักษาที่ดีกว่าในการติดตั้งใช้งานแอปพลิเคชัน Android แบบเพิ่ม
  • ระบบจัดการหน่วยความจำที่ไม่ใช้แล้วสำหรับแคชที่เก็บข้อมูลและ install_base ของ Bazel
  • ลดค่าใช้จ่ายในการแซนด์บ็อกซ์

การรองรับ Bazel-JetBrains* IntelliJ IDEA

การอัปเดตปลั๊กอิน IntelliJ แบบเพิ่มเพื่อรองรับปลั๊กอิน JetBrains รุ่นล่าสุด

โรดแมปนี้แสดงภาพรวมของเป้าหมายและไม่ควรนำไปใช้เป็นหลักประกัน ลำดับความสำคัญอาจมีการเปลี่ยนแปลงตามความคิดเห็นของนักพัฒนาซอฟต์แวร์และลูกค้า หรือโอกาสทางการตลาดใหม่ๆ

หากต้องการรับการแจ้งเตือนเกี่ยวกับฟีเจอร์ใหม่ๆ ซึ่งรวมถึงการอัปเดตโรดแมปนี้ ให้เข้าร่วมชุมชน Google Group

*Copyright © 2022 JetBrains s.r.o. JetBrains และ IntelliJ เป็นเครื่องหมายการค้าจดทะเบียนของ JetBrains s.r.o