# `buildx build [OPTIONS] PATH | URL | -` The `buildx build` command starts a build using BuildKit. This command is similar to the UI of `docker build` command and takes the same flags and arguments. Options: | Flag | Description | | --- | --- | | --add-host [] | Add a custom host-to-IP mapping (host:ip) | --allow [] | Allow extra privileged entitlement, e.g. network.host, security.insecure | --build-arg [] | Set build-time variables | --cache-from [] | External cache sources (eg. user/app:cache, type=local,src=path/to/dir) | --cache-to [] | Cache export destinations (eg. user/app:cache, type=local,dest=path/to/dir) | --file string | Name of the Dockerfile (Default is 'PATH/Dockerfile') | --iidfile string | Write the image ID to the file | --label [] | Set metadata for an image | --load | Shorthand for --output=type=docker | --network string | Set the networking mode for the RUN instructions during build (default "default") | --no-cache | Do not use cache when building the image | --output [] | Output destination (format: type=local,dest=path) | --platform [] | Set target platform for build | --progress string | Set type of progress output (auto, plain, tty). Use plain to show container output (default "auto") | --pull | Always attempt to pull a newer version of the image | --push | Shorthand for --output=type=registry | --secret [] | Secret file to expose to the build: id=mysecret,src=/local/secret | --ssh [] | SSH agent socket or keys to expose to the build (format: default\|<id>[=<socket>\|<key>[,<key>]]) | --tag [] | Name and optionally a tag in the 'name:tag' format | --target string | Set the target build stage to build. ## Description The `buildx build` command starts a build using BuildKit. This command is similar to the UI of `docker build` command and takes the same flags and arguments. For documentation on most of these flags refer to the [`docker build` documentation](https://docs.docker.com/engine/reference/commandline/build/). In here we’ll document a subset of the new flags. ### `--platform=value[,value]` Set the target platform for the build. All `FROM` commands inside the Dockerfile without their own `--platform` flag will pull base images for this platform and this value will also be the platform of the resulting image. The default value will be the current platform of the buildkit daemon. When using `docker-container` driver with `buildx`, this flag can accept multiple values as an input separated by a comma. With multiple values the result will be built for all of the specified platforms and joined together into a single manifest list. If the`Dockerfile` needs to invoke the `RUN` command, the builder needs runtime support for the specified platform. In a clean setup, you can only execute `RUN` commands for your system architecture. If your kernel supports [`binfmt_misc`](https://en.wikipedia.org/wiki/Binfmt_misc) launchers for secondary architectures buildx will pick them up automatically. Docker desktop releases come with binfmt_misc automatically configured for `arm64` and `arm` architectures. You can see what runtime platforms your current builder instance supports by running `docker buildx inspect --bootstrap`. Inside a `Dockerfile`, you can access the current platform value through `TARGETPLATFORM` build argument. Please refer to the [`docker build` documentation](https://docs.docker.com/engine/reference/builder/#automatic-platform-args-in-the-global-scope) for the full description of automatic platform argument variants . The formatting for the platform specifier is defined in the [containerd source code](https://github.com/containerd/containerd/blob/v1.4.3/platforms/platforms.go#L63). Examples: ```console docker buildx build --platform=linux/arm64 . docker buildx build --platform=linux/amd64,linux/arm64,linux/arm/v7 . docker buildx build --platform=darwin . ``` ### `-o, --output=[PATH,-,type=TYPE[,KEY=VALUE]` Sets the export action for the build result. In `docker build` all builds finish by creating a container image and exporting it to `docker images`. `buildx` makes this step configurable allowing results to be exported directly to the client, oci image tarballs, registry etc. Buildx with `docker` driver currently only supports local, tarball exporter and image exporter. `docker-container` driver supports all the exporters. If just the path is specified as a value, `buildx` will use the local exporter with this path as the destination. If the value is "-", `buildx` will use `tar` exporter and write to `stdout`. Examples: ```console docker buildx build -o . . docker buildx build -o outdir . docker buildx build -o - - > out.tar docker buildx build -o type=docker . docker buildx build -o type=docker,dest=- . > myimage.tar docker buildx build -t tonistiigi/foo -o type=registry ``` Supported exported types are: #### `local` The `local` export type writes all result files to a directory on the client. The new files will be owned by the current user. On multi-platform builds, all results will be put in subdirectories by their platform. Attribute key: - `dest` - destination directory where files will be written #### `tar` The `tar` export type writes all result files as a single tarball on the client. On multi-platform builds all results will be put in subdirectories by their platform. Attribute key: - `dest` - destination path where tarball will be written. “-” writes to stdout. #### `oci` The `oci` export type writes the result image or manifest list as an [OCI image layout](https://github.com/opencontainers/image-spec/blob/v1.0.1/image-layout.md) tarball on the client. Attribute key: - `dest` - destination path where tarball will be written. “-” writes to stdout. #### `docker` The `docker` export type writes the single-platform result image as a [Docker image specification](https://github.com/docker/docker/blob/v20.10.2/image/spec/v1.2.md) tarball on the client. Tarballs created by this exporter are also OCI compatible. Currently, multi-platform images cannot be exported with the `docker` export type. The most common usecase for multi-platform images is to directly push to a registry (see [`registry`](#registry)). Attribute keys: - `dest` - destination path where tarball will be written. If not specified the tar will be loaded automatically to the current docker instance. - `context` - name for the docker context where to import the result #### `image` The `image` exporter writes the build result as an image or a manifest list. When using `docker` driver the image will appear in `docker images`. Optionally image can be automatically pushed to a registry by specifying attributes. Attribute keys: - `name` - name (references) for the new image. - `push` - boolean to automatically push the image. #### `registry` The `registry` exporter is a shortcut for `type=image,push=true`. ### `--push` Shorthand for [`--output=type=registry`](#registry). Will automatically push the build result to registry. ### `--load` Shorthand for [`--output=type=docker`](#docker). Will automatically load the single-platform build result to `docker images`. ### `--cache-from=[NAME|type=TYPE[,KEY=VALUE]]` Use an external cache source for a build. Supported types are `registry` and `local`. The `registry` source can import cache from a cache manifest or (special) image configuration on the registry. The `local` source can import cache from local files previously exported with `--cache-to`. If no type is specified, `registry` exporter is used with a specified reference. `docker` driver currently only supports importing build cache from the registry. Examples: ```console docker buildx build --cache-from=user/app:cache . docker buildx build --cache-from=user/app . docker buildx build --cache-from=type=registry,ref=user/app . docker buildx build --cache-from=type=local,src=path/to/cache . ``` ### `--cache-to=[NAME|type=TYPE[,KEY=VALUE]]` Export build cache to an external cache destination. Supported types are `registry`, `local` and `inline`. Registry exports build cache to a cache manifest in the registry, local exports cache to a local directory on the client and inline writes the cache metadata into the image configuration. `docker` driver currently only supports exporting inline cache metadata to image configuration. Alternatively, `--build-arg BUILDKIT_INLINE_CACHE=1` can be used to trigger inline cache exporter. Attribute key: - `mode` - Specifies how many layers are exported with the cache. “min” on only exports layers already in the final build stage, “max” exports layers for all stages. Metadata is always exported for the whole build. Examples: ```console docker buildx build --cache-to=user/app:cache . docker buildx build --cache-to=type=inline . docker buildx build --cache-to=type=registry,ref=user/app . docker buildx build --cache-to=type=local,dest=path/to/cache . ``` ### `--allow=ENTITLEMENT` Allow extra privileged entitlement. List of entitlements: - `network.host` - Allows executions with host networking. - `security.insecure` - Allows executions without sandbox. See [related Dockerfile extensions](https://github.com/moby/buildkit/blob/master/frontend/dockerfile/docs/experimental.md#run---securityinsecuresandbox). For entitlements to be enabled, the `buildkitd` daemon also needs to allow them with `--allow-insecure-entitlement` (see [`create --buildkitd-flags`](buildx_create.md#--buildkitd-flags-flags)) Examples: ```console $ docker buildx create --use --name insecure-builder --buildkitd-flags '--allow-insecure-entitlement security.insecure' $ docker buildx build --allow security.insecure . ```