Tình trạng dị thường

Báo cáo sự cố Xem nguồn

Trang này đề cập đến tính trắc nghiệm, lợi ích của việc sử dụng bản dựng khép kín và chiến lược để xác định hành vi không khép kín trong bản dựng.

Tổng quan

Khi được cung cấp cùng một mã nguồn đầu vào và cấu hình sản phẩm, hệ thống xây dựng khép kín luôn trả về cùng một kết quả bằng cách tách riêng bản dựng khỏi các thay đổi đối với hệ thống lưu trữ.

Để tách biệt bản dựng, các bản dựng khép kín không nhạy cảm với thư viện và phần mềm khác được cài đặt trên máy chủ cục bộ hoặc máy chủ từ xa. Chúng phụ thuộc vào các phiên bản cụ thể của công cụ xây dựng, chẳng hạn như trình biên dịch và phần phụ thuộc, chẳng hạn như thư viện. Điều này làm cho quá trình xây dựng độc lập vì nó không dựa vào các dịch vụ bên ngoài môi trường bản dựng.

Hai khía cạnh quan trọng của độ chi tiết là:

  • Tách biệt: Hệ thống xây dựng Hermetic coi các công cụ là mã nguồn. Họ tải các bản sao của công cụ xuống và quản lý bộ nhớ cũng như sử dụng bên trong cây tệp được quản lý. Điều này tạo ra sự tách biệt giữa máy chủ và người dùng cục bộ, bao gồm cả các phiên bản ngôn ngữ được cài đặt.
  • Nhận dạng nguồn: Hệ thống xây dựng Hermetic cố gắng đảm bảo tính giống nhau của các dữ liệu đầu vào. Các kho lưu trữ mã, chẳng hạn như Git, xác định các tập hợp đột biến mã bằng một mã băm duy nhất. Các hệ thống xây dựng Hermetic sử dụng hàm băm này để xác định các thay đổi đối với đầu vào của bản dựng.

Lợi ích

Những lợi ích chính của các bản dựng khép kín là:

  • Tốc độ: Đầu ra của một hành động có thể được lưu vào bộ nhớ đệm và không cần chạy lại hành động đó trừ khi dữ liệu đầu vào thay đổi.
  • Thực thi song song: Đối với đầu vào và đầu ra nhất định, hệ thống xây dựng có thể tạo biểu đồ của tất cả các hành động để tính toán việc thực thi hiệu quả và song song. Hệ thống xây dựng sẽ tải các quy tắc và tính toán biểu đồ hành động cũng như dữ liệu đầu vào băm để tra cứu trong bộ nhớ đệm.
  • Nhiều bản dựng: Bạn có thể tạo nhiều bản dựng khép kín trên cùng một máy, mỗi bản dựng sử dụng các công cụ và phiên bản khác nhau.
  • Khả năng tái lập: Bản dựng Hermetic rất phù hợp để khắc phục sự cố vì bạn biết chính xác những điều kiện đã tạo ra bản dựng.

Xác định tình trạng không bình thường

Nếu bạn đang chuẩn bị chuyển sang Bazel, việc di chuyển sẽ dễ dàng hơn nếu bạn cải thiện trước độ linh hoạt của các bản dựng hiện có. Sau đây là một số nguồn không chính xác thông thường trong bản dựng:

  • Xử lý tuỳ ý trong .mk tệp
  • Các thao tác hoặc công cụ tạo tệp không xác định, thường liên quan đến mã nhận dạng bản dựng hoặc dấu thời gian
  • Các tệp nhị phân của hệ thống khác nhau giữa các máy chủ (chẳng hạn như tệp nhị phân /usr/bin, đường dẫn tuyệt đối, trình biên dịch hệ thống C++ cho tính năng tự động định cấu hình quy tắc C++ gốc)
  • Ghi vào cây nguồn trong quá trình tạo. Việc này sẽ ngăn việc sử dụng cùng một cây nguồn cho một mục tiêu khác. Bản dựng đầu tiên ghi vào cây nguồn, sửa cây nguồn cho mục tiêu A. Sau đó, việc cố gắng tạo mục tiêu B có thể không thành công.

Khắc phục sự cố bản dựng không phải ngoài trời

Bắt đầu khi thực thi cục bộ, các vấn đề ảnh hưởng đến lượt truy cập bộ nhớ đệm cục bộ sẽ cho thấy các hành động không có ý nghĩa.

  • Đảm bảo bản dựng tuần tự rỗng: Nếu bạn chạy make và có được một bản dựng thành công, việc chạy lại bản dựng sẽ không tạo lại bất kỳ mục tiêu nào. Nếu bạn chạy mỗi bước hai bản dựng hoặc trên các hệ thống khác nhau, hãy so sánh một hàm băm của nội dung tệp và nhận được kết quả khác nhau, bản dựng này không thể tái lập.
  • Chạy các bước để gỡ lỗi lượt truy cập bộ nhớ đệm cục bộ từ nhiều máy khách tiềm năng để đảm bảo rằng bạn nắm bắt được mọi trường hợp môi trường máy khách bị rò rỉ trong các hành động.
  • Thực thi một bản dựng trong vùng chứa Docker không chứa gì ngoài cây nguồn đã kiểm tra và danh sách các công cụ lưu trữ rõ ràng. Các sự cố bản dựng và thông báo lỗi sẽ phát hiện các phần phụ thuộc hệ thống ngầm ẩn.
  • Khám phá và khắc phục các vấn đề về độ kín bằng quy tắc thực thi từ xa.
  • Bật hộp cát nghiêm ngặt ở cấp độ mỗi hành động, vì các hành động trong một bản dựng có thể ở trạng thái và ảnh hưởng đến bản dựng hoặc đầu ra.
  • Quy tắc không gian làm việc cho phép nhà phát triển thêm các phần phụ thuộc vào không gian làm việc bên ngoài, nhưng họ đủ phong phú để cho phép xử lý tùy ý trong quá trình này. Bạn có thể ghi lại nhật ký một số hành động có thể không có ý nghĩa trong quy tắc không gian làm việc của Bazel bằng cách thêm cờ --experimental_workspace_rules_log_file=PATH vào lệnh Bazel.

Hermeticity cùng Bazel

Để biết thêm thông tin về cách những dự án khác đã thành công khi sử dụng các bản dựng khép kín thông qua Bazel, hãy xem các bài nói chuyện sau đây của BazelCon: