2021-10-30 09:50:23 -03:00
|
|
|
# Docker Images
|
2017-09-12 22:16:23 -03:00
|
|
|
|
2021-09-27 22:43:00 -03:00
|
|
|
GoReleaser can build and push Docker images.
|
|
|
|
Let's see how it works.
|
2017-09-12 22:16:23 -03:00
|
|
|
|
|
|
|
## How it works
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
You can declare multiple Docker images. They will be matched against
|
2021-01-07 16:21:12 -03:00
|
|
|
the binaries generated by your `builds` section and packages generated
|
|
|
|
by your `nfpms` section.
|
2017-09-12 22:16:23 -03:00
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
If you have only one `build` setup,
|
|
|
|
the configuration is as easy as adding the
|
2021-12-23 01:52:01 +01:00
|
|
|
name of your image to your `.goreleaser.yaml` file:
|
2017-09-12 22:16:23 -03:00
|
|
|
|
|
|
|
```yaml
|
|
|
|
dockers:
|
2018-10-20 21:26:16 +08:00
|
|
|
- image_templates:
|
|
|
|
- user/repo
|
2017-09-12 22:16:23 -03:00
|
|
|
```
|
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
!!! tip
|
|
|
|
The `image_templates` attribute supports templating. Learn more about the [name template engine](/customization/templates/).
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
You also need to create a `Dockerfile` in your project's root folder:
|
2017-09-12 22:16:23 -03:00
|
|
|
|
|
|
|
```dockerfile
|
|
|
|
FROM scratch
|
|
|
|
ENTRYPOINT ["/mybin"]
|
2021-01-07 16:21:12 -03:00
|
|
|
COPY mybin /
|
2017-09-12 22:16:23 -03:00
|
|
|
```
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
This configuration will build and push a Docker image named `user/repo:tagname`.
|
2017-09-12 22:16:23 -03:00
|
|
|
|
2020-11-26 23:19:46 -03:00
|
|
|
!!! warning
|
2021-07-03 22:19:16 +00:00
|
|
|
Note that we are not building any go files in the Docker
|
2020-05-10 16:57:11 -03:00
|
|
|
build phase, we are merely copying the binary to a `scratch` image and
|
2020-11-26 23:19:46 -03:00
|
|
|
setting up the `entrypoint`.
|
2018-06-06 10:44:52 -03:00
|
|
|
|
2017-09-12 22:16:23 -03:00
|
|
|
## Customization
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
Of course, you can customize a lot of things:
|
2017-09-12 22:16:23 -03:00
|
|
|
|
|
|
|
```yaml
|
2021-12-23 01:52:01 +01:00
|
|
|
# .goreleaser.yaml
|
2017-09-12 22:16:23 -03:00
|
|
|
dockers:
|
2017-10-01 18:57:52 +02:00
|
|
|
# You can have multiple Docker images.
|
2017-09-12 22:16:23 -03:00
|
|
|
-
|
2021-08-16 22:11:54 -03:00
|
|
|
# ID of the image, needed if you want to filter by it later on (e.g. on custom publishers).
|
|
|
|
id: myimg
|
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
# GOOS of the built binaries/packages that should be used.
|
2017-09-12 22:16:23 -03:00
|
|
|
goos: linux
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
# GOARCH of the built binaries/packages that should be used.
|
2017-09-12 22:16:23 -03:00
|
|
|
goarch: amd64
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
# GOARM of the built binaries/packages that should be used.
|
2017-09-12 22:16:23 -03:00
|
|
|
goarm: ''
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
# IDs to filter the binaries/packages.
|
|
|
|
ids:
|
2019-12-27 11:55:03 -03:00
|
|
|
- mybuild
|
2021-01-07 16:21:12 -03:00
|
|
|
- mynfpm
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2018-10-20 21:26:16 +08:00
|
|
|
# Templates of the Docker image names.
|
|
|
|
image_templates:
|
|
|
|
- "myuser/myimage:latest"
|
|
|
|
- "myuser/myimage:{{ .Tag }}"
|
|
|
|
- "myuser/myimage:{{ .Tag }}-{{ .Env.GO_VERSION }}"
|
|
|
|
- "myuser/myimage:v{{ .Major }}"
|
|
|
|
- "gcr.io/myuser/myimage:latest"
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2021-06-16 23:00:08 -03:00
|
|
|
# Skips the docker push.
|
|
|
|
# Could be useful if you also do draft releases.
|
|
|
|
#
|
2021-07-03 22:19:16 +00:00
|
|
|
# If set to auto, the release will not be pushed to the Docker repository
|
2021-06-16 23:00:08 -03:00
|
|
|
# in case there is an indicator of a prerelease in the tag, e.g. v1.0.0-rc1.
|
|
|
|
#
|
2018-03-24 18:42:21 -03:00
|
|
|
# Defaults to false.
|
|
|
|
skip_push: false
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
# Path to the Dockerfile (from the project root).
|
2022-01-06 15:34:55 -03:00
|
|
|
#
|
|
|
|
# Defaults to `Dockerfile`.
|
|
|
|
dockerfile: '{{ .Env.DOCKERFILE }}'
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2021-07-03 22:19:16 +00:00
|
|
|
# Set the "backend" for the Docker pipe.
|
2022-03-17 07:55:17 -03:00
|
|
|
# Valid options are: docker, buildx, podman.
|
2021-07-03 22:19:16 +00:00
|
|
|
# podman is a GoReleaser Pro feature and is only available on Linux.
|
2021-06-26 16:36:31 -03:00
|
|
|
# Defaults to docker.
|
|
|
|
use: docker
|
2021-01-04 11:27:27 -03:00
|
|
|
|
2018-10-03 21:11:40 +08:00
|
|
|
# Template of the docker build flags.
|
|
|
|
build_flag_templates:
|
2020-01-26 16:06:21 +01:00
|
|
|
- "--pull"
|
|
|
|
- "--label=org.opencontainers.image.created={{.Date}}"
|
2020-07-17 12:49:38 -04:00
|
|
|
- "--label=org.opencontainers.image.title={{.ProjectName}}"
|
2020-01-26 16:06:21 +01:00
|
|
|
- "--label=org.opencontainers.image.revision={{.FullCommit}}"
|
|
|
|
- "--label=org.opencontainers.image.version={{.Version}}"
|
2019-07-16 23:10:45 +02:00
|
|
|
- "--build-arg=FOO={{.Env.Bar}}"
|
2021-01-04 11:27:27 -03:00
|
|
|
- "--platform=linux/arm64"
|
2019-12-27 11:55:03 -03:00
|
|
|
|
2021-07-03 22:19:16 +00:00
|
|
|
# Extra flags to be passed down to the push command.
|
|
|
|
# Defaults to empty.
|
|
|
|
push_flags:
|
|
|
|
- --tls-verify=false
|
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
# If your Dockerfile copies files other than binaries and packages,
|
2017-09-25 19:10:04 -03:00
|
|
|
# you should list them here as well.
|
2021-01-07 16:21:12 -03:00
|
|
|
# Note that GoReleaser will create the same structure inside a temporary
|
2018-12-16 11:11:01 -02:00
|
|
|
# folder, so if you add `foo/bar.json` here, on your Dockerfile you can
|
|
|
|
# `COPY foo/bar.json /whatever.json`.
|
|
|
|
# Also note that the paths here are relative to the folder in which
|
2021-01-07 16:21:12 -03:00
|
|
|
# GoReleaser is being run (usually the repository root folder).
|
2018-12-16 11:11:01 -02:00
|
|
|
# This field does not support wildcards, you can add an entire folder here
|
|
|
|
# and use wildcards when you `COPY`/`ADD` in your Dockerfile.
|
2017-09-25 19:10:04 -03:00
|
|
|
extra_files:
|
|
|
|
- config.yml
|
2017-09-12 22:16:23 -03:00
|
|
|
```
|
|
|
|
|
2020-05-10 18:59:21 -03:00
|
|
|
!!! tip
|
2020-11-19 12:31:26 -08:00
|
|
|
Learn more about the [name template engine](/customization/templates/).
|
2018-07-08 23:57:46 -07:00
|
|
|
|
2021-01-04 11:27:27 -03:00
|
|
|
!!! tip
|
|
|
|
You can also create multi-platform images using the [docker_manifests](/customization/docker_manifest/) config.
|
|
|
|
|
2017-10-01 18:57:52 +02:00
|
|
|
These settings should allow you to generate multiple Docker images,
|
|
|
|
for example, using multiple `FROM` statements,
|
2021-01-07 16:21:12 -03:00
|
|
|
as well as generate one image for each binary in your project or one image with multiple binaries, as well as
|
|
|
|
install the generated packages instead of copying the binary and configs manually.
|
2017-12-06 00:13:16 +01:00
|
|
|
|
2018-10-05 11:00:25 -05:00
|
|
|
## Generic Image Names
|
|
|
|
|
|
|
|
Some users might want to keep their image name as generic as possible.
|
|
|
|
That can be accomplished simply by adding template language in the definition:
|
|
|
|
|
|
|
|
```yaml
|
2021-12-23 01:52:01 +01:00
|
|
|
# .goreleaser.yaml
|
2018-10-12 00:08:39 -03:00
|
|
|
project: foo
|
2018-10-05 11:00:25 -05:00
|
|
|
dockers:
|
|
|
|
-
|
2018-10-20 21:26:16 +08:00
|
|
|
image_templates:
|
|
|
|
- "myuser/{{.ProjectName}}"
|
2018-10-05 11:00:25 -05:00
|
|
|
```
|
|
|
|
|
2021-05-07 08:44:20 -04:00
|
|
|
This will build and publish the following images:
|
2018-10-05 11:00:25 -05:00
|
|
|
|
2018-10-12 00:08:39 -03:00
|
|
|
- `myuser/foo`
|
|
|
|
|
2020-05-10 18:59:21 -03:00
|
|
|
!!! tip
|
2020-11-19 12:31:26 -08:00
|
|
|
Learn more about the [name template engine](/customization/templates/).
|
2018-10-05 11:00:25 -05:00
|
|
|
|
2018-01-19 00:05:09 -02:00
|
|
|
## Keeping docker images updated for current major
|
|
|
|
|
2021-05-05 08:32:57 -04:00
|
|
|
Some users might want to push docker tags `:v1`, `:v1.6`,
|
2018-01-19 00:05:09 -02:00
|
|
|
`:v1.6.4` and `:latest` when `v1.6.4` (for example) is built. That can be
|
2018-10-20 21:26:16 +08:00
|
|
|
accomplished by using multiple `image_templates`:
|
2018-01-19 00:05:09 -02:00
|
|
|
|
|
|
|
```yaml
|
2021-12-23 01:52:01 +01:00
|
|
|
# .goreleaser.yaml
|
2018-01-19 00:05:09 -02:00
|
|
|
dockers:
|
|
|
|
-
|
2018-10-20 21:26:16 +08:00
|
|
|
image_templates:
|
|
|
|
- "myuser/myimage:{{ .Tag }}"
|
|
|
|
- "myuser/myimage:v{{ .Major }}"
|
|
|
|
- "myuser/myimage:v{{ .Major }}.{{ .Minor }}"
|
|
|
|
- "myuser/myimage:latest"
|
2018-01-19 00:05:09 -02:00
|
|
|
```
|
|
|
|
|
|
|
|
This will build and publish the following images:
|
|
|
|
|
2018-06-06 10:44:52 -03:00
|
|
|
- `myuser/myimage:v1.6.4`
|
|
|
|
- `myuser/myimage:v1`
|
|
|
|
- `myuser/myimage:v1.6`
|
|
|
|
- `myuser/myimage:latest`
|
2018-01-19 00:05:09 -02:00
|
|
|
|
2021-01-07 16:21:12 -03:00
|
|
|
With these settings you can hopefully push several Docker images
|
2018-02-18 20:37:59 -03:00
|
|
|
with multiple tags.
|
2018-10-03 21:11:40 +08:00
|
|
|
|
2020-05-10 18:59:21 -03:00
|
|
|
!!! tip
|
2020-11-19 12:31:26 -08:00
|
|
|
Learn more about the [name template engine](/customization/templates/).
|
2018-10-12 00:08:39 -03:00
|
|
|
|
2018-10-20 21:26:16 +08:00
|
|
|
## Publishing to multiple docker registries
|
|
|
|
|
|
|
|
Some users might want to push images to multiple docker registries. That can be
|
|
|
|
accomplished by using multiple `image_templates`:
|
|
|
|
|
|
|
|
```yaml
|
2021-12-23 01:52:01 +01:00
|
|
|
# .goreleaser.yaml
|
2018-10-20 21:26:16 +08:00
|
|
|
dockers:
|
|
|
|
-
|
|
|
|
image_templates:
|
|
|
|
- "docker.io/myuser/myimage:{{ .Tag }}"
|
|
|
|
- "docker.io/myuser/myimage:latest"
|
|
|
|
- "gcr.io/myuser/myimage:{{ .Tag }}"
|
|
|
|
- "gcr.io/myuser/myimage:latest"
|
|
|
|
```
|
|
|
|
|
|
|
|
This will build and publish the following images to `docker.io` and `gcr.io`:
|
|
|
|
|
|
|
|
- `myuser/myimage:v1.6.4`
|
|
|
|
- `myuser/myimage:latest`
|
2021-01-07 16:21:12 -03:00
|
|
|
- `gcr.io/myuser/myimage:v1.6.4`
|
|
|
|
- `gcr.io/myuser/myimage:latest`
|
2018-10-20 21:26:16 +08:00
|
|
|
|
2021-07-03 22:19:16 +00:00
|
|
|
## Applying Docker build flags
|
2018-10-03 21:11:40 +08:00
|
|
|
|
2021-07-03 22:19:16 +00:00
|
|
|
Build flags can be applied using `build_flag_templates`.
|
|
|
|
The flags must be valid Docker build flags.
|
2018-10-03 21:11:40 +08:00
|
|
|
|
|
|
|
```yaml
|
2021-12-23 01:52:01 +01:00
|
|
|
# .goreleaser.yaml
|
2018-10-03 21:11:40 +08:00
|
|
|
dockers:
|
|
|
|
-
|
2018-10-20 21:26:16 +08:00
|
|
|
image_templates:
|
2019-01-11 16:27:39 -02:00
|
|
|
- "myuser/myimage"
|
2018-10-03 21:11:40 +08:00
|
|
|
build_flag_templates:
|
2020-01-26 16:06:21 +01:00
|
|
|
- "--pull"
|
|
|
|
- "--label=org.opencontainers.image.created={{.Date}}"
|
2020-07-17 12:49:38 -04:00
|
|
|
- "--label=org.opencontainers.image.title={{.ProjectName}}"
|
2020-01-26 16:06:21 +01:00
|
|
|
- "--label=org.opencontainers.image.revision={{.FullCommit}}"
|
|
|
|
- "--label=org.opencontainers.image.version={{.Version}}"
|
2018-10-03 21:11:40 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
This will execute the following command:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
docker build -t myuser/myimage . \
|
2020-01-26 16:06:21 +01:00
|
|
|
--pull \
|
2020-06-15 15:52:41 +03:00
|
|
|
--label=org.opencontainers.image.created=2020-01-19T15:58:07Z \
|
2020-07-17 12:49:38 -04:00
|
|
|
--label=org.opencontainers.image.title=mybinary \
|
2020-06-15 15:52:41 +03:00
|
|
|
--label=org.opencontainers.image.revision=da39a3ee5e6b4b0d3255bfef95601890afd80709 \
|
2020-01-26 16:06:21 +01:00
|
|
|
--label=org.opencontainers.image.version=1.6.4
|
2018-10-03 21:11:40 +08:00
|
|
|
```
|
2018-10-12 00:08:39 -03:00
|
|
|
|
2020-05-10 18:59:21 -03:00
|
|
|
!!! tip
|
2020-11-19 12:31:26 -08:00
|
|
|
Learn more about the [name template engine](/customization/templates/).
|
2021-07-03 22:19:16 +00:00
|
|
|
|
|
|
|
## Podman
|
|
|
|
|
2021-09-22 23:30:16 -03:00
|
|
|
!!! success "GoReleaser Pro"
|
|
|
|
The podman backend is a [GoReleaser Pro feature](/pro/).
|
|
|
|
|
2021-07-03 22:19:16 +00:00
|
|
|
You can use [`podman`](https://podman.io) instead of `docker` by setting `use` to `podman` on your config:
|
|
|
|
|
|
|
|
```yaml
|
2021-12-23 01:52:01 +01:00
|
|
|
# .goreleaser.yaml
|
2021-07-03 22:19:16 +00:00
|
|
|
dockers:
|
|
|
|
-
|
|
|
|
image_templates:
|
|
|
|
- "myuser/myimage"
|
|
|
|
use: podman
|
|
|
|
```
|
|
|
|
|
|
|
|
Note that GoReleaser will not install Podman for you, nor change any of its configuration.
|
|
|
|
|