Skip to content

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:

Terminal window
git clone https://github.com/TraceMachina/nativelink && \
cd nativelink && \
nix develop

This environment contains some cloud tooling, so you don’t need to set up any kubernetes-related software yourself.

Now, start the development cluster:

Terminal window
native up

Once the infra is ready, trigger the pipelines that build the images:

Terminal window
cat > dummy-repo.yaml << EOF
apiVersion: source.toolkit.fluxcd.io/v1
kind: GitRepository
metadata:
name: dummy-repository
namespace: default
spec:
interval: 2m
url: https://github.com/TraceMachina/nativelink
ref:
branch: main
EOF
kubectl apply -f dummy-repo.yaml

Next, deploy NativeLink to the cluster:

Terminal window
kubectl apply -k \
https://github.com/TraceMachina/nativelink//deploy/chromium-example

🔭 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 a PipelineRun 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.

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:

Terminal window
build-chromium-tests

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:

Terminal window
watch $HOME/chromium/src/buildtools/reclient/reproxystatus

🧹 Clean up

When you’re done testing, delete the cluster:

Terminal window
# Delete the kind cluster
native down
# Remove the container registry and loadbalancer
docker container stop kind-registry | xargs docker rm
docker container stop kind-loadbalancer | xargs docker rm