You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
106 lines
4.3 KiB
Markdown
106 lines
4.3 KiB
Markdown
3 years ago
|
# Docker container driver
|
||
|
|
||
2 years ago
|
The buildx Docker container driver allows creation of a managed and customizable
|
||
|
BuildKit environment in a dedicated Docker container.
|
||
3 years ago
|
|
||
2 years ago
|
Using the Docker container driver has a couple of advantages over the default
|
||
|
Docker driver. For example:
|
||
3 years ago
|
|
||
2 years ago
|
- Specify custom BuildKit versions to use.
|
||
|
- Build multi-arch images, see [QEMU](#qemu)
|
||
|
- Advanced options for
|
||
2 years ago
|
[cache import and export](../cache/backends/index.md)
|
||
2 years ago
|
|
||
|
## Synopsis
|
||
|
|
||
|
Run the following command to create a new builder, named `container`, that uses
|
||
|
the Docker container driver:
|
||
3 years ago
|
|
||
|
```console
|
||
2 years ago
|
$ docker buildx create \
|
||
|
--name container \
|
||
|
--driver=docker-container \
|
||
|
--driver-opt=[key=value,...]
|
||
3 years ago
|
container
|
||
|
```
|
||
|
|
||
2 years ago
|
The following table describes the available driver-specific options that you can
|
||
|
pass to `--driver-opt`:
|
||
3 years ago
|
|
||
2 years ago
|
| Parameter | Value | Default | Description |
|
||
|
| --------------- | ------ | ---------------- | ------------------------------------------------------------------------------------------ |
|
||
2 years ago
|
| `image` | String | | Sets the image to use for running BuildKit. |
|
||
|
| `network` | String | | Sets the network mode for running the BuildKit container. |
|
||
|
| `cgroup-parent` | String | `/docker/buildx` | Sets the cgroup parent of the BuildKit container if Docker is using the `cgroupfs` driver. |
|
||
3 years ago
|
|
||
2 years ago
|
## Usage
|
||
|
|
||
2 years ago
|
When you run a build, Buildx pulls the specified `image` (by default,
|
||
2 years ago
|
[`moby/buildkit`](https://hub.docker.com/r/moby/buildkit)). When the container
|
||
|
has started, Buildx submits the build submitted to the containerized build
|
||
|
server.
|
||
3 years ago
|
|
||
|
```console
|
||
2 years ago
|
$ docker buildx build -t <image> --builder=container .
|
||
3 years ago
|
WARNING: No output specified with docker-container driver. Build result will only remain in the build cache. To push result image into registry use --push or to load image into docker use --load
|
||
|
#1 [internal] booting buildkit
|
||
|
#1 pulling image moby/buildkit:buildx-stable-1
|
||
|
#1 pulling image moby/buildkit:buildx-stable-1 1.9s done
|
||
|
#1 creating container buildx_buildkit_container0
|
||
|
#1 creating container buildx_buildkit_container0 0.5s done
|
||
|
#1 DONE 2.4s
|
||
|
...
|
||
|
```
|
||
|
|
||
2 years ago
|
## Loading to local image store
|
||
|
|
||
|
Unlike when using the default `docker` driver, images built with the
|
||
|
`docker-container` driver must be explicitly loaded into the local image store.
|
||
|
Use the `--load` flag:
|
||
3 years ago
|
|
||
|
```console
|
||
2 years ago
|
$ docker buildx build --load -t <image> --builder=container .
|
||
3 years ago
|
...
|
||
|
=> exporting to oci image format 7.7s
|
||
|
=> => exporting layers 4.9s
|
||
2 years ago
|
=> => exporting manifest sha256:4e4ca161fa338be2c303445411900ebbc5fc086153a0b846ac12996960b479d3 0.0s
|
||
|
=> => exporting config sha256:adf3eec768a14b6e183a1010cb96d91155a82fd722a1091440c88f3747f1f53f 0.0s
|
||
|
=> => sending tarball 2.8s
|
||
|
=> importing to docker
|
||
3 years ago
|
```
|
||
|
|
||
2 years ago
|
The image becomes available in the image store when the build finishes:
|
||
3 years ago
|
|
||
|
```console
|
||
|
$ docker image ls
|
||
|
REPOSITORY TAG IMAGE ID CREATED SIZE
|
||
|
<image> latest adf3eec768a1 2 minutes ago 197MB
|
||
|
```
|
||
3 years ago
|
|
||
2 years ago
|
### QEMU
|
||
|
|
||
|
The `docker-container` driver supports using [QEMU](https://www.qemu.org/) (user
|
||
|
mode) to build non-native platforms. Use the `--platform` flag to specify which
|
||
|
architectures that you want to build for.
|
||
|
|
||
|
For example, to build a Linux image for `amd64` and `arm64`:
|
||
|
|
||
|
```console
|
||
2 years ago
|
$ docker buildx build \
|
||
2 years ago
|
--builder=container \
|
||
|
--platform=linux/amd64,linux/arm64 \
|
||
|
-t <registry>/<image> \
|
||
2 years ago
|
--push .
|
||
2 years ago
|
```
|
||
|
|
||
|
> **Warning**
|
||
|
>
|
||
|
> QEMU performs full-system emulation of non-native platforms, which is much
|
||
|
> slower than native builds. Compute-heavy tasks like compilation and
|
||
|
> compression/decompression will likely take a large performance hit.
|
||
|
|
||
3 years ago
|
## Further reading
|
||
|
|
||
2 years ago
|
For more information on the Docker container driver, see the
|
||
|
[buildx reference](https://docs.docker.com/engine/reference/commandline/buildx_create/#driver).
|