From 5ec703ba10eb560c145d5ef356396883e451a8c7 Mon Sep 17 00:00:00 2001 From: David Karlsson <35727626+dvdksn@users.noreply.github.com> Date: Fri, 28 Jun 2024 15:22:22 +0200 Subject: [PATCH] docs: reference description for --call and --check Signed-off-by: David Karlsson <35727626+dvdksn@users.noreply.github.com> --- docs/reference/buildx_build.md | 165 ++++++++++++++++++++++++++++++++- 1 file changed, 163 insertions(+), 2 deletions(-) diff --git a/docs/reference/buildx_build.md b/docs/reference/buildx_build.md index 398b5a534a1..ebe410c3807 100644 --- a/docs/reference/buildx_build.md +++ b/docs/reference/buildx_build.md @@ -24,9 +24,9 @@ Start a build | [`--builder`](#builder) | `string` | | Override the configured builder instance | | [`--cache-from`](#cache-from) | `stringArray` | | External cache sources (e.g., `user/app:cache`, `type=local,src=path/to/dir`) | | [`--cache-to`](#cache-to) | `stringArray` | | Cache export destinations (e.g., `user/app:cache`, `type=local,dest=path/to/dir`) | -| `--call` | `string` | `build` | Set method for evaluating build (`check`, `outline`, `targets`) | +| [`--call`](#call) | `string` | `build` | Set method for evaluating build (`check`, `outline`, `targets`) | | [`--cgroup-parent`](#cgroup-parent) | `string` | | Set the parent cgroup for the `RUN` instructions during build | -| `--check` | `bool` | | Shorthand for `--call=check` | +| [`--check`](#check) | `bool` | | Shorthand for `--call=check` | | `--detach` | `bool` | | Detach buildx server (supported only on linux) (EXPERIMENTAL) | | [`-f`](#file), [`--file`](#file) | `string` | | Name of the Dockerfile (default: `PATH/Dockerfile`) | | `--iidfile` | `string` | | Write the image ID to a file | @@ -325,6 +325,167 @@ $ docker buildx build --cache-from=type=s3,region=eu-west-1,bucket=mybucket . More info about cache exporters and available attributes: https://github.com/moby/buildkit#export-cache +### Invoke a frontend method (--call) + +```text +--call=[build|check|outline|targets] +``` + +BuildKit frontends can support alternative modes of executions for builds, +using frontend methods. Frontend methods are a way to change or extend the +behavior of a build invocation, which lets you, for example, inspect, validate, +or generate alternative outputs from a build. + +The `--call` flag for `docker buildx build` lets you specify the frontend +method that you want to execute. If this flag is unspecified, it defaults to +executing the build and evaluating [build checks](https://docs.docker.com/reference/build-checks/). + +For Dockerfiles, the available methods are: + +| Command | Description | +| ------------------------------ | ------------------------------------------------------------------------------------------------------------------- | +| `build` (default) | Execute the build and evaluate build checks for the current build target. | +| `check` | Evaluate build checks for the either the entire Dockerfile or the selected target, without executing a build. | +| `outline` | Show the build arguments that you can set for a target, and their default values. | +| `targets` | List all the build targets in the Dockerfile. | +| `subrequests.describe` | List all the frontend methods that the current frontend supports. | + +Note that other frontends may implement these or other methods. +To see the list of available methods for the frontend you're using, +use `--call=subrequests.describe`. + +```console +$ docker buildx build -q --call=subrequests.describe . + +NAME VERSION DESCRIPTION +outline 1.0.0 List all parameters current build target supports +targets 1.0.0 List all targets current build supports +subrequests.describe 1.0.0 List available subrequest types +``` + +#### Descriptions + +The [`--call=targets`](#call-targets) and [`--call=outline`](#call-outline) +methods include descriptions for build targets and arguments, if available. +Descriptions are generated from comments in the Dockerfile. A comment on the +line before a `FROM` instruction becomes the description of a build target, and +a comment before an `ARG` instruction the description of a build argument. The +comment must lead with the name of the stage or argument, for example: + +```dockerfile +# syntax=docker/dockerfile:1 + +# GO_VERSION sets the Go version for the build +ARG GO_VERSION=1.22 + +# base-builder is the base stage for building the project +FROM golang:${GO_VERSION} AS base-builder +``` + +When you run `docker buildx build --call=outline`, the output includes the +descriptions, as follows: + +```console +$ docker buildx build -q --call=outline . + +TARGET: base-builder +DESCRIPTION: is the base stage for building the project + +BUILD ARG VALUE DESCRIPTION +GO_VERSION 1.22 sets the Go version for the build +``` + +For more examples on how to write Dockerfile docstrings, +check out [the Dockerfile for Docker docs](https://github.com/docker/docs/blob/main/Dockerfile). + +#### Call: check (--check) + +The `check` method evaluates build checks without executing the build. The +`--check` flag is a convenient shorthand for `--call=check`. Use the `check` +method to validate the build configuration before starting the build. + +```console +$ docker buildx build -q --check https://github.com/docker/docs.git + +WARNING: InvalidBaseImagePlatform +Base image wjdp/htmltest:v0.17.0 was pulled with platform "linux/amd64", expected "linux/arm64" for current build +Dockerfile:43 +-------------------- + 41 | "#content/desktop/previous-versions/*.md" + 42 | + 43 | >>> FROM wjdp/htmltest:v${HTMLTEST_VERSION} AS test + 44 | WORKDIR /test + 45 | COPY --from=build /out ./public +-------------------- +``` + +Using `--check` without specifying a target evaluates the entire Dockerfile. +If you want to evaluate a specific target, use the `--target` flag. + +#### Call: outline + +The `outline` method prints the name of the specified target (or the default +target, if `--target` isn't specified), and the build arguments that the target +consumes, along with their default values, if set. + +The following example shows the default target `release` and its build arguments: + +```console +$ docker buildx build -q --call=outline https://github.com/docker/docs.git + +TARGET: release +DESCRIPTION: is an empty scratch image with only compiled assets + +BUILD ARG VALUE DESCRIPTION +GO_VERSION 1.22 sets the Go version for the base stage +HUGO_VERSION 0.127.0 +HUGO_ENV sets the hugo.Environment (production, development, preview) +DOCS_URL sets the base URL for the site +PAGEFIND_VERSION 1.1.0 +``` + +This means that the `release` target is configurable using these build arguments: + +```console +$ docker buildx build \ + --build-arg GO_VERSION=1.22 \ + --build-arg HUGO_VERSION=0.127.0 \ + --build-arg HUGO_ENV=production \ + --build-arg DOCS_URL=https://example.com \ + --build-arg PAGEFIND_VERSION=1.1.0 \ + --target release https://github.com/docker/docs.git +``` + +#### Call: targets + +The `targets` method lists all the build targets in the Dockerfile. These are +the stages that you can build using the `--target` flag. It also indicates the +default target, which is the target that will be built when you don't specify a +target. + +```console +$ docker buildx build -q --call=targets https://github.com/docker/docs.git + +TARGET DESCRIPTION +base is the base stage with build dependencies +node installs Node.js dependencies +hugo downloads and extracts the Hugo binary +build-base is the base stage for building the site +dev is for local development with Docker Compose +build creates production builds with Hugo +lint lints markdown files +test validates HTML output and checks for broken links +update-modules downloads and vendors Hugo modules +vendor is an empty stage with only vendored Hugo modules +build-upstream builds an upstream project with a replacement module +validate-upstream validates HTML output for upstream builds +unused-media checks for unused graphics and other media +pagefind installs the Pagefind runtime +index generates a Pagefind index +test-go-redirects checks that the /go/ redirects are valid +release (default) is an empty scratch image with only compiled assets +``` + ### Export build cache to an external cache destination (--cache-to) ```text