docker buildx bake [OPTIONS] [TARGET...]
Build from a file
docker buildx bake
, docker buildx f
Name | Type | Default | Description |
---|---|---|---|
--allow |
stringArray |
Allow build to access specified resources | |
--builder |
string |
Override the configured builder instance | |
--call |
string |
build |
Set method for evaluating build (check , outline , targets ) |
--check |
bool |
Shorthand for --call=check |
|
-D , --debug |
bool |
Enable debug logging | |
-f , --file |
stringArray |
Build definition file | |
--list |
string |
List targets or variables | |
--load |
bool |
Shorthand for --set=*.output=type=docker |
|
--metadata-file |
string |
Write build result metadata to a file | |
--no-cache |
bool |
Do not use cache when building the image | |
--print |
bool |
Print the options without building | |
--progress |
string |
auto |
Set type of progress output (auto , quiet , plain , tty , rawjson ). Use plain to show container output |
--provenance |
string |
Shorthand for --set=*.attest=type=provenance |
|
--pull |
bool |
Always attempt to pull all referenced images | |
--push |
bool |
Shorthand for --set=*.output=type=registry |
|
--sbom |
string |
Shorthand for --set=*.attest=type=sbom |
|
--set |
stringArray |
Override target value (e.g., targetpattern.key=value ) |
Bake is a high-level build command. Each specified target runs in parallel as part of the build.
Read High-level build options with Bake guide for introduction to writing bake files.
Note
buildx bake
command may receive backwards incompatible features in the future
if needed. We are looking for feedback on improving the command and extending
the functionality further.
Same as buildx --builder
.
Same as build --call
.
Same as build --check
.
Use the -f
/ --file
option to specify the build definition file to use.
The file can be an HCL, JSON or Compose file. If multiple files are specified,
all are read and the build configurations are combined.
You can pass the names of the targets to build, to build only specific target(s).
The following example builds the db
and webapp-release
targets that are
defined in the docker-bake.dev.hcl
file:
# docker-bake.dev.hcl
group "default" {
targets = ["db", "webapp-dev"]
}
target "webapp-dev" {
dockerfile = "Dockerfile.webapp"
tags = ["docker.io/username/webapp"]
}
target "webapp-release" {
inherits = ["webapp-dev"]
platforms = ["linux/amd64", "linux/arm64"]
}
target "db" {
dockerfile = "Dockerfile.db"
tags = ["docker.io/username/db"]
}
$ docker buildx bake -f docker-bake.dev.hcl db webapp-release
See the Bake file reference for more details.
The --list
flag displays all available targets or variables in the Bake
configuration, along with a description (if set using the description
property in the Bake file).
To list all targets:
$ docker buildx bake --list=targets
TARGET DESCRIPTION
binaries
default binaries
update-docs
validate
validate-golangci Validate .golangci.yml schema (does not run Go linter)
To list variables:
$ docker buildx bake --list=variables
VARIABLE VALUE DESCRIPTION
REGISTRY docker.io/username Registry and namespace
IMAGE_NAME my-app Image name
GO_VERSION <null>
By default, the output of docker buildx bake --list
is presented in a table
format. Alternatively, you can use a long-form CSV syntax and specify a
format
attribute to output the list in JSON.
$ docker buildx bake --list=type=targets,format=json
Similar to buildx build --metadata-file
but
writes a map of results for each target such as:
# docker-bake.hcl
group "default" {
targets = ["db", "webapp-dev"]
}
target "db" {
dockerfile = "Dockerfile.db"
tags = ["docker.io/username/db"]
}
target "webapp-dev" {
dockerfile = "Dockerfile.webapp"
tags = ["docker.io/username/webapp"]
}
$ docker buildx bake --load --metadata-file metadata.json .
$ cat metadata.json
{
"buildx.build.warnings": {},
"db": {
"buildx.build.provenance": {},
"buildx.build.ref": "mybuilder/mybuilder0/0fjb6ubs52xx3vygf6fgdl611",
"containerimage.config.digest": "sha256:2937f66a9722f7f4a2df583de2f8cb97fc9196059a410e7f00072fc918930e66",
"containerimage.descriptor": {
"annotations": {
"config.digest": "sha256:2937f66a9722f7f4a2df583de2f8cb97fc9196059a410e7f00072fc918930e66",
"org.opencontainers.image.created": "2022-02-08T21:28:03Z"
},
"digest": "sha256:19ffeab6f8bc9293ac2c3fdf94ebe28396254c993aea0b5a542cfb02e0883fa3",
"mediaType": "application/vnd.oci.image.manifest.v1+json",
"size": 506
},
"containerimage.digest": "sha256:19ffeab6f8bc9293ac2c3fdf94ebe28396254c993aea0b5a542cfb02e0883fa3"
},
"webapp-dev": {
"buildx.build.provenance": {},
"buildx.build.ref": "mybuilder/mybuilder0/kamngmcgyzebqxwu98b4lfv3n",
"containerimage.config.digest": "sha256:9651cc2b3c508f697c9c43b67b64c8359c2865c019e680aac1c11f4b875b67e0",
"containerimage.descriptor": {
"annotations": {
"config.digest": "sha256:9651cc2b3c508f697c9c43b67b64c8359c2865c019e680aac1c11f4b875b67e0",
"org.opencontainers.image.created": "2022-02-08T21:28:15Z"
},
"digest": "sha256:6d9ac9237a84afe1516540f40a0fafdc86859b2141954b4d643af7066d598b74",
"mediaType": "application/vnd.oci.image.manifest.v1+json",
"size": 506
},
"containerimage.digest": "sha256:6d9ac9237a84afe1516540f40a0fafdc86859b2141954b4d643af7066d598b74"
}
}
Note
Build record provenance
(buildx.build.provenance
) includes minimal provenance by default. Set the
BUILDX_METADATA_PROVENANCE
environment variable to customize this behavior:
min
sets minimal provenance (default).max
sets full provenance.disabled
,false
or0
does not set any provenance.
Note
Build warnings (buildx.build.warnings
) are not included by default. Set the
BUILDX_METADATA_WARNINGS
environment variable to 1
or true
to
include them.
Same as build --no-cache
. Don't use cache when building the image.
Prints the resulting options of the targets desired to be built, in a JSON format, without starting a build.
$ docker buildx bake -f docker-bake.hcl --print db
{
"group": {
"default": {
"targets": [
"db"
]
}
},
"target": {
"db": {
"context": "./",
"dockerfile": "Dockerfile",
"tags": [
"docker.io/tiborvass/db"
]
}
}
}
Same as build --progress
.
Same as build --provenance
.
Same as build --pull
.
Same as build --sbom
.
--set targetpattern.key[.subkey]=value
Override target configurations from command line. The pattern matching syntax is defined in https://golang.org/pkg/path/#Match.
$ docker buildx bake --set target.args.mybuildarg=value
$ docker buildx bake --set target.platform=linux/arm64
$ docker buildx bake --set foo*.args.mybuildarg=value # overrides build arg for all targets starting with 'foo'
$ docker buildx bake --set *.platform=linux/arm64 # overrides platform for all targets
$ docker buildx bake --set foo*.no-cache # bypass caching only for targets starting with 'foo'
You can override the following fields:
args
cache-from
cache-to
context
dockerfile
labels
load
no-cache
no-cache-filter
output
platform
pull
push
secrets
ssh
tags
target