Giới thiệu về Bazel

Bazel là một công cụ kiểm thử và xây dựng nguồn mở tương tự như Make, Maven và Gradle. Tính năng này sử dụng ngôn ngữ bản dựng cấp cao, mà con người có thể đọc được. Bazel hỗ trợ các dự án bằng nhiều ngôn ngữ và tạo đầu ra cho nhiều nền tảng. Bazel hỗ trợ các cơ sở mã lớn trên nhiều kho lưu trữ và với số lượng lớn người dùng.

Lợi ích

Bazel có những ưu điểm sau:

  • Ngôn ngữ xây dựng cấp cao. Bazel sử dụng một ngôn ngữ trừu tượng mà con người có thể đọc được để mô tả các thuộc tính bản dựng của dự án ở cấp độ ngữ nghĩa cao. Không giống như các công cụ khác, Bazel hoạt động dựa trên khái niệm về thư viện, tệp nhị phân, tập lệnh và tập dữ liệu, giúp bạn tránh sự phức tạp khi ghi các lệnh gọi riêng lẻ đến các công cụ như trình biên dịch và trình liên kết.

  • Bazel hoạt động rất nhanh và đáng tin cậy. Bazel lưu mọi công việc đã thực hiện trước đó vào bộ nhớ đệm và theo dõi các thay đổi đối với cả nội dung tệp lẫn lệnh tạo. Bằng cách này, Bazel biết khi nào cần xây dựng lại thứ gì đó và chỉ xây dựng lại điều đó. Để tăng tốc hơn nữa các bản dựng, bạn có thể thiết lập dự án để xây dựng theo kiểu song song và tăng dần ở mức độ cao.

  • Bazel là một nền tảng đa nền tảng. Bazel chạy trên Linux, macOS và Windows. Bazel có thể tạo các tệp nhị phân và các gói có thể triển khai cho nhiều nền tảng (bao gồm cả máy tính, máy chủ và thiết bị di động) trong cùng một dự án.

  • Cân nhắc việc Bazel. Bazel duy trì sự linh hoạt trong khi xử lý các bản dựng có hơn 100 nghìn tệp nguồn. Công cụ này hoạt động với nhiều kho lưu trữ và cơ sở người dùng lên đến hàng chục nghìn.

  • Bazel có thể mở rộng. Nhiều ngôn ngữ được hỗ trợ và bạn có thể mở rộng Bazel để hỗ trợ bất kỳ ngôn ngữ hoặc khung nào khác.

Sử dụng Bazel

Để tạo hoặc kiểm thử một dự án bằng Bazel, bạn thường làm như sau:

  1. Thiết lập Bazel. Tải xuống và cài đặt Bazel.

  2. Thiết lập một dự án không gian làm việc. Đây là thư mục nơi Bazel tìm kiếm dữ liệu đầu vào của bản dựng và tệp BUILD, đồng thời là nơi lưu trữ đầu ra của bản dựng.

  3. Viết một tệp BUILD để cho Bazel biết cần tạo gì và cách tạo tệp đó.

    Bạn viết tệp BUILD bằng cách khai báo mục tiêu bản dựng bằng Starlark, một ngôn ngữ dành riêng cho miền. (Xem ví dụ tại đây.)

    Mục tiêu bản dựng chỉ định một tập hợp cấu phần phần mềm đầu vào mà Bazel sẽ tạo cùng với các phần phụ thuộc, quy tắc xây dựng Bazel sẽ sử dụng để tạo mục tiêu và các tuỳ chọn giúp định cấu hình quy tắc xây dựng.

    Quy tắc xây dựng chỉ định các công cụ xây dựng mà Bazel sẽ sử dụng, chẳng hạn như trình biên dịch và trình liên kết, cũng như cấu hình của các công cụ đó. Bazel cung cấp một số quy tắc xây dựng bao gồm những loại cấu phần phần mềm phổ biến nhất bằng các ngôn ngữ được hỗ trợ trên các nền tảng được hỗ trợ.

  4. Chạy Bazel qua dòng lệnh. Bazel đặt kết quả của bạn vào không gian làm việc.

Ngoài việc tạo bản dựng, bạn cũng có thể sử dụng Bazel để chạy kiểm thửtruy vấn bản dựng để theo dõi các phần phụ thuộc trong mã của bạn.

Quy trình xây dựng Bazel

Khi chạy một bản dựng hoặc một kiểm thử, Bazel sẽ thực hiện những việc sau:

  1. Tải các tệp BUILD liên quan đến mục tiêu.

  2. Phân tích dữ liệu đầu vào và các phần phụ thuộc của chúng, áp dụng các quy tắc bản dựng được chỉ định và tạo biểu đồ hành động.

  3. Thực thi các hành động tạo trên các đầu vào cho đến khi tạo ra kết quả đầu ra cuối cùng của bản dựng.

Vì mọi công việc tạo bản dựng trước đó đều được lưu vào bộ nhớ đệm, nên Bazel có thể xác định và sử dụng lại các cấu phần phần mềm đã lưu vào bộ nhớ đệm, đồng thời chỉ tạo lại hoặc kiểm thử lại những nội dung thay đổi. Để tăng cường độ chính xác, bạn có thể thiết lập Bazel để chạy các bản dựng và kiểm thử theo hình học thông qua hộp cát, giảm thiểu độ lệch và tối đa hoá độ tái tạo.

Biểu đồ hành động

Biểu đồ hành động thể hiện các cấu phần phần mềm của bản dựng, mối quan hệ giữa chúng và những hành động tạo bản dựng mà Bazel sẽ thực hiện. Nhờ biểu đồ này, Bazel có thể theo dõi các thay đổi đối với nội dung tệp cũng như các thay đổi đối với hành động, chẳng hạn như lệnh tạo hoặc kiểm thử, đồng thời biết được công việc tạo bản dựng nào đã thực hiện trước đó. Biểu đồ này cũng cho phép bạn dễ dàng theo dõi các phần phụ thuộc trong mã của mình.

Hướng dẫn bắt đầu

Để bắt đầu sử dụng Bazel, hãy xem phần Bắt đầu hoặc chuyển thẳng đến các hướng dẫn về Bazel: