Theo dõi các phần phụ thuộc trong WORKSPACE
Bất cứ khi nào có thể, hãy có một chính sách phiên bản duy nhất trong dự án. Chính sách này là bắt buộc đối với các phần phụ thuộc mà bạn biên dịch và kết thúc trong tệp nhị phân cuối cùng. Đối với các trường hợp khác, bạn có thể theo dõi các phần phụ thuộc:
myproject/WORKSPACE
workspace(name = "myproject")
local_repository(
name = "A",
path = "../A",
)
local_repository(
name = "B",
path = "../B",
)
A/WORKSPACE
workspace(name = "A")
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
name = "testrunner",
urls = ["https://github.com/testrunner/v1.zip"],
sha256 = "...",
)
B/WORKSPACE
workspace(name = "B")
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
name = "testrunner",
urls = ["https://github.com/testrunner/v2.zip"],
sha256 = "..."
)
Cả hai phần phụ thuộc A
và B
đều phụ thuộc vào các phiên bản khác nhau của testrunner
.
Đưa cả hai vào myproject
mà không xung đột bằng cách đặt tên riêng biệt cho chúng trong myproject/WORKSPACE
:
workspace(name = "myproject")
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
name = "testrunner-v1",
urls = ["https://github.com/testrunner/v1.zip"],
sha256 = "..."
)
http_archive(
name = "testrunner-v2",
urls = ["https://github.com/testrunner/v2.zip"],
sha256 = "..."
)
local_repository(
name = "A",
path = "../A",
repo_mapping = {"@testrunner" : "@testrunner-v1"}
)
local_repository(
name = "B",
path = "../B",
repo_mapping = {"@testrunner" : "@testrunner-v2"}
)
Bạn cũng có thể sử dụng cơ chế này để kết hợp các kim cương. Ví dụ: nếu A
và B
có cùng một phần phụ thuộc nhưng gọi phần phụ thuộc đó bằng các tên khác nhau, hãy kết hợp các phần phụ thuộc đó trong myproject/WORKSPACE
.
Ghi đè kho lưu trữ từ dòng lệnh
Để ghi đè kho lưu trữ đã khai báo bằng kho lưu trữ cục bộ từ dòng lệnh, hãy sử dụng cờ --override_repository
. Việc sử dụng cờ này sẽ thay đổi nội dung của các kho lưu trữ bên ngoài mà không thay đổi mã nguồn của bạn.
Ví dụ: để ghi đè @foo
vào thư mục cục bộ /path/to/local/foo
, hãy truyền cờ --override_repository=foo=/path/to/local/foo
.
Các trường hợp sử dụng bao gồm:
- Các vấn đề về gỡ lỗi. Ví dụ: để ghi đè kho lưu trữ
http_archive
vào một thư mục cục bộ, nơi bạn có thể dễ dàng thực hiện các thay đổi. - Nhà cung cấp. Nếu bạn đang ở trong môi trường không thể thực hiện lệnh gọi mạng, hãy ghi đè các quy tắc kho lưu trữ dựa trên mạng để trỏ đến các thư mục cục bộ.
Sử dụng proxy
Bazel sẽ lấy địa chỉ proxy từ các biến môi trường HTTPS_PROXY
và HTTP_PROXY
và sử dụng các địa chỉ này để tải tệp HTTP
và HTTPS
xuống (nếu được chỉ định).
Hỗ trợ IPv6
Trên các máy chỉ có IPv6, Bazel có thể tải các phần phụ thuộc xuống mà không cần thay đổi. Tuy nhiên, trên các máy IPv4/IPv6 có ngăn xếp kép, Bazel tuân theo cùng một quy ước như Java, ưu tiên IPv4 nếu được bật. Trong một số trường hợp, chẳng hạn như khi mạng IPv4 không thể phân giải/đến các địa chỉ bên ngoài, điều này có thể gây ra các ngoại lệ Network
unreachable
và lỗi bản dựng. Trong những trường hợp này, bạn có thể ghi đè hành vi của Bazel để ưu tiên IPv6 bằng cách sử dụng thuộc tính hệ thống java.net.preferIPv6Addresses=true
.
Cụ thể:
Sử dụng tuỳ chọn khởi động
--host_jvm_args=-Djava.net.preferIPv6Addresses=true
, ví dụ: bằng cách thêm dòng sau vào tệp.bazelrc
:startup --host_jvm_args=-Djava.net.preferIPv6Addresses=true
Khi chạy các mục tiêu bản dựng Java cần kết nối với Internet (chẳng hạn như để kiểm thử tích hợp), hãy sử dụng cờ công cụ
--jvmopt=-Djava.net.preferIPv6Addresses=true
. Ví dụ: đưa vào tệp.bazelrc
:build --jvmopt=-Djava.net.preferIPv6Addresses
Nếu bạn đang sử dụng
rules_jvm_external
để phân giải phiên bản phần phụ thuộc, hãy thêm-Djava.net.preferIPv6Addresses=true
vào biến môi trườngCOURSIER_OPTS
để cung cấp các tuỳ chọn JVM cho Coursier.
Bản dựng ngoại tuyến
Đôi khi, bạn có thể muốn chạy bản dựng ngoại tuyến, chẳng hạn như khi đi máy bay. Đối với các trường hợp sử dụng đơn giản như vậy, hãy tải trước các kho lưu trữ cần thiết bằng bazel fetch
hoặc bazel sync
. Để tắt tính năng tìm nạp các kho lưu trữ khác trong quá trình tạo bản dựng, hãy sử dụng tuỳ chọn --nofetch
.
Đối với các bản dựng ngoại tuyến thực sự, trong đó một thực thể khác cung cấp tất cả các tệp cần thiết, Bazel hỗ trợ tuỳ chọn --distdir
. Cờ này yêu cầu Bazel trước tiên phải xem xét các thư mục do tuỳ chọn đó chỉ định khi một quy tắc kho lưu trữ yêu cầu Bazel tìm nạp tệp bằng ctx.download
hoặc ctx.download_and_extract
. Bằng cách cung cấp tổng băm của tệp cần thiết, Bazel sẽ tìm một tệp khớp với tên cơ sở của URL đầu tiên và sử dụng bản sao cục bộ nếu hàm băm khớp.
Bản thân Bazel sử dụng kỹ thuật này để khởi động từ xa từ cấu phần phần mềm phân phối.
Công cụ này thực hiện việc này bằng cách thu thập tất cả các phần phụ thuộc bên ngoài cần thiết trong một distdir_tar
nội bộ.
Bazel cho phép thực thi các lệnh tuỳ ý trong quy tắc kho lưu trữ mà không biết liệu các lệnh đó có gọi đến mạng hay không, do đó không thể thực thi các bản dựng hoàn toàn ngoại tuyến. Để kiểm thử xem một bản dựng có hoạt động chính xác khi không có mạng hay không, hãy chặn mạng theo cách thủ công (như Bazel thực hiện trong kiểm thử khởi động).