Mô hình phát hành

Như đã thông báo trong bài đăng trên blog gốc, Bazel 4.0 trở lên hỗ trợ 2 kênh phát hành: bản phát hành liên tục và bản phát hành hỗ trợ dài hạn (LTS). Trang này cung cấp thông tin mới nhất về mô hình phát hành của Bazel.

Ma trận hỗ trợ

Bản phát hành LTS Giai đoạn hỗ trợ Phiên bản mới nhất Ngừng hỗ trợ
Bazel 10 Liên tục Kiểm tra trang bản phát hành liên tục Không áp dụng
Bazel 9 Đang hoạt động 9.0.2 Tháng 12 năm 2028
Bazel 8 Đang bảo trì 8.6.0 Tháng 12 năm 2027
Bazel 7 Đang bảo trì 7.7.1 Tháng 12 năm 2026
Bazel 6 Không được dùng nữa 6.6.0 Tháng 12 năm 2025
Bazel 5 Không được dùng nữa 5.4.1 Tháng 1 năm 2025
Bazel 4 Không được dùng nữa 4.2.4 Tháng 1 năm 2024

Bạn có thể tìm thấy tất cả các bản phát hành LTS của Bazel trên trang phát hành trên GitHub.

Phiên bản phát hành

Bazel sử dụng lược đồ lập phiên bản ngữ nghĩa major.minor.patch Semantic Versioning.

  • Bản phát hành chính chứa các tính năng không tương thích ngược với bản phát hành trước. Mỗi phiên bản chính của Bazel là một bản phát hành LTS.
  • Bản phát hành phụ chứa các bản sửa lỗi và tính năng tương thích ngược được chuyển ngược từ nhánh chính.
  • Bản phát hành bản vá chứa các bản sửa lỗi nghiêm trọng.

Ngoài ra, các bản phát hành trước được biểu thị bằng cách thêm dấu gạch nối và hậu tố ngày vào số phiên bản lớn tiếp theo.

Ví dụ: bản phát hành mới của mỗi loại sẽ dẫn đến các số phiên bản sau:

  • Chính: 6.0.0
  • Phụ: 6.1.0
  • Bản vá: 6.1.2
  • Bản phát hành trước: 7.0.0-pre.20230502.1

Giai đoạn hỗ trợ

Đối với mỗi phiên bản chính của Bazel, có 4 giai đoạn hỗ trợ:

  • Liên tục: Phiên bản lớn này vẫn đang ở giai đoạn phát hành trước, nhóm Bazel phát hành các bản phát hành liên tục từ HEAD.
  • Đang hoạt động: Phiên bản lớn này là bản phát hành LTS đang hoạt động hiện tại. Nhóm Bazel chuyển ngược các tính năng quan trọng và bản sửa lỗi vào các bản phát hành phụ.
  • Đang bảo trì: Phiên bản lớn này là một bản phát hành LTS cũ ở chế độ bảo trì. Nhóm Bazel chỉ hứa sẽ chuyển ngược các bản sửa lỗi nghiêm trọng cho các vấn đề về bảo mật và khả năng tương thích với hệ điều hành vào bản phát hành LTS này.
  • Không được dùng nữa: Nhóm Bazel không còn hỗ trợ phiên bản chính này nữa, tất cả người dùng nên di chuyển sang các bản phát hành LTS mới hơn của Bazel.

Nhịp độ phát hành

Bazel thường xuyên phát hành các bản phát hành cho 2 kênh phát hành.

Bản phát hành liên tục

  • Các bản phát hành liên tục được phối hợp với bản phát hành Google Blaze và được phát hành từ HEAD khoảng 2 tuần một lần. Đây là bản xem trước của bản phát hành LTS tiếp theo của Bazel.
  • Các bản phát hành liên tục có thể gửi các thay đổi không tương thích. Bạn nên sử dụng các cờ không tương thích cho các thay đổi lớn gây lỗi, việc triển khai các thay đổi không tương thích phải tuân theo chính sách tương thích ngược của chúng tôi.

Bản phát hành LTS

  • Bản phát hành chính: Dự kiến sẽ cắt một bản phát hành LTS mới từ HEAD khoảng 12 tháng một lần. Sau khi bản phát hành LTS mới được phát hành, bản phát hành này sẽ ngay lập tức chuyển sang giai đoạn Đang hoạt động và bản phát hành LTS trước đó sẽ chuyển sang giai đoạn Đang bảo trì.
  • Bản phát hành phụ: Dự kiến các phiên bản phụ mới trên kênh LTS đang hoạt động sẽ được phát hành 2 tháng một lần.
  • Bản phát hành bản vá: Dự kiến các phiên bản bản vá mới cho các bản phát hành LTS ở giai đoạn Đang hoạt động và Đang bảo trì sẽ được phát hành theo yêu cầu để sửa các lỗi nghiêm trọng.
  • Bản phát hành LTS của Bazel sẽ chuyển sang giai đoạn Không được dùng nữa sau khi ở giai đoạn Đang bảo trì trong 2 năm.

Đối với các bản phát hành đã lên kế hoạch, vui lòng kiểm tra các vấn đề về bản phát hành trên Github.

Quy trình và chính sách phát hành

Đối với các bản phát hành liên tục, quy trình này rất đơn giản: khoảng 2 tuần một lần, một bản phát hành mới sẽ được tạo, phù hợp với cùng một đường cơ sở như bản phát hành Blaze nội bộ của Google. Do lịch phát hành nhanh chóng, chúng tôi không chuyển ngược bất kỳ thay đổi nào sang các bản phát hành liên tục.

Đối với các bản phát hành LTS, chúng tôi tuân theo quy trình và chính sách dưới đây:

  1. Xác định một cam kết cơ sở cho bản phát hành.
    • Đối với bản phát hành LTS chính mới, cam kết cơ sở là HEAD của nhánh chính.
    • Đối với bản phát hành phụ hoặc bản vá, cam kết cơ sở là HEAD của phiên bản mới nhất hiện tại của cùng một bản phát hành LTS.
  2. Tạo một nhánh phát hành có tên là release-<version> từ cam kết cơ sở.
  3. Chuyển ngược các thay đổi thông qua PR sang nhánh phát hành.
    • Cộng đồng có thể đề xuất một số cam kết được chuyển ngược bằng cách trả lời "@bazel-io flag" trên các vấn đề hoặc PR có liên quan trên GitHub để đánh dấu các cam kết đó là các yếu tố có khả năng chặn bản phát hành. Nhóm Bazel sẽ phân loại các cam kết đó và quyết định có chuyển ngược các cam kết đó hay không.
    • Chỉ các cam kết tương thích ngược trên nhánh chính mới có thể được chuyển ngược, các thay đổi nhỏ bổ sung để giải quyết xung đột hợp nhất đều được chấp nhận.
  4. Chuyển ngược các thay đổi bằng cách sử dụng Vấn đề yêu cầu chọn cam kết cho người duy trì Bazel.

    • Người duy trì Bazel có thể yêu cầu chọn lọc cam kết cụ thể sang một nhánh phát hành. Quy trình này được bắt đầu bằng cách tạo một yêu cầu chọn lọc trên GitHub. Sau đây là cách thực hiện.

      1. Mở yêu cầu chọn lọc
      2. Điền thông tin chi tiết về yêu cầu
        • Tiêu đề: Cung cấp tiêu đề ngắn gọn và mang tính mô tả cho yêu cầu.
        • Mã cam kết: Nhập mã của (các) cam kết mà bạn muốn chọn lọc. Nếu có nhiều cam kết, hãy phân tách các cam kết đó bằng dấu phẩy.
        • Danh mục: Chỉ định danh mục của yêu cầu.
        • Người xem xét: Đối với nhiều người xem xét, hãy phân tách mã GitHub của họ bằng dấu phẩy.
      3. Đặt cột mốc
        • Tìm phần "Cột mốc" rồi nhấp vào chế độ cài đặt.
        • Chọn các yếu tố chặn bản phát hành X.Y.Z phù hợp. Hành động này kích hoạt bot chọn lọc để xử lý yêu cầu của bạn cho nhánh "release-X.Y.Z".
      4. Gửi vấn đề
        • Sau khi điền tất cả thông tin chi tiết và đặt cột mốc, hãy gửi vấn đề.
    • Bot chọn lọc sẽ xử lý yêu cầu và thông báo nếu(các) cam kết đủ điều kiện để chọn lọc. Nếu các cam kết có thể chọn cam kết (nghĩa là không có xung đột hợp nhất trong khi chọn cam kết), thì bot sẽ tạo một yêu cầu kéo mới. Khi yêu cầu kéo được một thành viên của nhóm Bazel phê duyệt, các cam kết sẽ được chọn và hợp nhất vào nhánh phát hành. Để xem ví dụ trực quan về yêu cầu chọn lọc đã hoàn tất, hãy tham khảo ví dụ này .

  5. Xác định các yếu tố chặn bản phát hành và khắc phục các vấn đề được tìm thấy trên nhánh phát hành.

    • Nhánh phát hành được kiểm thử bằng cùng một bộ thử nghiệm trong postsubmitquy trình kiểm thử hạ nguồn trên Bazel CI. Nhóm Bazel giám sát kết quả kiểm thử của nhánh phát hành và khắc phục mọi lỗi hồi quy được tìm thấy.
  6. Tạo một bản phát hành dùng thử mới từ nhánh phát hành khi tất cả các yếu tố chặn bản phát hành đã biết đều được giải quyết.

    • Bản phát hành dùng thử được công bố trên bazel-discuss, nhóm Bazel giám sát các báo cáo lỗi của cộng đồng cho bản phát hành dùng thử.
    • Nếu xác định được các yếu tố chặn bản phát hành mới, hãy quay lại bước cuối cùng và tạo một bản phát hành dùng thử mới sau khi giải quyết tất cả các vấn đề.
    • Không được phép thêm các tính năng mới vào nhánh phát hành sau khi tạo bản phát hành dùng thử đầu tiên; các cam kết được chọn chỉ giới hạn ở các bản sửa lỗi nghiêm trọng. Nếu cần chọn lọc, người yêu cầu phải trả lời các câu hỏi sau: Tại sao thay đổi này lại quan trọng và thay đổi này mang lại những lợi ích gì? Khả năng thay đổi này gây ra lỗi hồi quy là bao nhiêu?
  7. Đẩy bản phát hành dùng thử làm bản phát hành chính thức nếu không tìm thấy thêm yếu tố chặn bản phát hành

    • Đối với các bản phát hành bản vá, hãy đẩy bản phát hành ít nhất 2 ngày làm việc sau khi bản phát hành dùng thử cuối cùng được phát hành.
    • Đối với các bản phát hành chính và phụ, hãy đẩy bản phát hành 2 ngày làm việc sau khi bản phát hành dùng thử cuối cùng được phát hành, nhưng không sớm hơn 1 tuần sau khi bản phát hành dùng thử đầu tiên được phát hành.
    • Bản phát hành chỉ được đẩy vào ngày mà ngày tiếp theo là ngày làm việc.
    • Bản phát hành được công bố trên bazel-discuss, nhóm Bazel giám sát và giải quyết các báo cáo lỗi của cộng đồng cho bản phát hành mới.

Báo cáo lỗi hồi quy

Nếu người dùng phát hiện thấy lỗi hồi quy trong bản phát hành mới của Bazel, bản phát hành dùng thử hoặc thậm chí là Bazel ở HEAD, vui lòng gửi báo cáo lỗi trên GitHub. Bạn có thể sử dụng Bazelisk để chia đôi cam kết gây ra lỗi và đưa thông tin này vào báo cáo lỗi.

Ví dụ: nếu bản dựng của bạn thành công với Bazel 6.1.0 nhưng không thành công với bản phát hành dùng thử thứ hai của 6.2.0, bạn có thể chia đôi thông qua

bazelisk --bisect=6.1.0..release-6.2.0rc2 build //foo:bar

Bạn có thể đặt biến môi trường BAZELISK_SHUTDOWN hoặc BAZELISK_CLEAN để chạy các lệnh bazel tương ứng nhằm đặt lại trạng thái bản dựng nếu cần thiết để tái tạo vấn đề. Để biết thêm thông tin chi tiết, hãy xem tài liệu về tính năng chia đôi của Bazelisk .

Hãy nhớ nâng cấp Bazelisk lên phiên bản mới nhất để sử dụng tính năng chia đôi.

Khả năng tương thích của quy tắc

Nếu bạn là tác giả quy tắc và muốn duy trì khả năng tương thích với các phiên bản Bazel khác nhau, vui lòng xem trang Khả năng tương thích của quy tắc.