NativeLink deployment example for Chromium
In this example you’ll spin up a local Kubernetes cluster with NativeLink and run a Chromium build against it.
Requirements
- An
x86_64-linux
system running a recent Ubuntu. Either “real” Linux or WSL2. - A functional local Docker setup.
- A recent version of Nix with flake support, for instance installed via the next-gen Nix installer.
☁️ Prepare the cluster
First, enter the NativeLink development environment:
This environment contains some cloud tooling, so you don’t need to set up any kubernetes-related software yourself.
Now, start the development cluster:
Once the infra is ready, trigger the pipelines that build the images:
Next, deploy NativeLink to the cluster:
🔭 Explore deployments
The deployment might take a wile to boot up. You can monitor progress via the dashboards that come with the development cluster:
- localhost:8080: Cilium’s Hubble UI to view the
cluster topology. NativeLink will be deployed into the
default
namespace. - localhost:8081: The Tekton Dashboard to view the
progress of the in-cluster pipelines. You’ll find the pipelines under the
PipelineRuns
tab. - localhost:9000: The Capacitor Dashboard to view Flux Kustomizations. You can view NatieLink’s logs here once it’s fully deployed.
In terminals, the following commands can be helpful to view deployment progress:
tkn pr logs -f
to view the logs of aPipelineRun
in the terminal.flux get all -A
to view the state of the NativeLink deployments.
Once NativeLink is deployed:
kubectl logs deploy/nativelink-cas
for the CAS (cache) logs.kubectl logs deploy/nativelink-scheduler
for the scheduler logs.kubectl logs deploy/nativelink-worker
for the worker logs.
🏗️ Build against NativeLink
The demo setup creates gateways to expose the cas
and scheduler
deployments
via your local docker network. The following command builds the Chromium tests
against the cluster:
The build-chromium-tests
command simplifies the setup described in
linux/build_instructions.md.
After preparing the requirements, it runs a Reclient build against the cluster.
You can view Reclient’s logs like so:
🧹 Clean up
When you’re done testing, delete the cluster: