Build Process
User Experience
When you create a Recipe on the dashboard (at DevZero: Create a new recipe), this is what you see...
To learn more about the various stages of the recipe specification, go to Execution Stages. To learn more about the specification, go to Recipe Syntax.
Underlying Architecture
The broad set of steps that go into building and publishing a recipe, and subsequently launching a workspace are as follows:
YAML recipe converted into an LLB.
If environment variables are referenced (stored under Environment Variables), they are validated and referenced directly in the LLB.
All steps that involve commands being run are base64-encoded and passed as input to a binary called
dzlaunch
(for cleaner handling of outputs from commands) - this binary is also available in a launched workspace.Once the LLB is ready, its sent to an async queue (
buildqd
) for it to get built and made available to be launched as a workspace.
Buildqd
workers are responsible for building OCI-compatible images and pushing it to a team-specific OCI image registry (completely namespaced/isolated).First, LLBs are sent to
buildkitd
following a similar pattern to howbuildctl
handles it (but using a buildkit client directly) - we do this to be able to give the user raw as well as well structured logs.Secrets, if any, are retrieved from Vault and injected into the build worker - this is one of the ways to ensure logical isolation.
If there were previous builds of the recipe, those caches are retrieved from the isolated OCI image registry to enable faster builds.
While the build is running, logs are streamed into a message queue to be made available to the different clients (web UI, CLI, etc).
Once the build is completed, the image (and cached layers) are pushed to the team-specific OCI image registry.
How It Works
Last updated