2022-10-12 00:12:42 -03:00
|
|
|
# Splitting and Merging builds
|
|
|
|
|
2022-10-12 01:12:38 -03:00
|
|
|
GoReleaser can also split and merge builds.
|
|
|
|
|
2023-04-02 17:16:21 -03:00
|
|
|
> Since: v1.12 (pro)
|
2022-10-12 01:04:51 -03:00
|
|
|
|
2022-10-12 00:12:42 -03:00
|
|
|
!!! success "GoReleaser Pro"
|
2022-10-12 01:01:24 -03:00
|
|
|
This subcommand is a [GoReleaser Pro feature](https://goreleaser.com/pro/).
|
2022-10-12 00:12:42 -03:00
|
|
|
|
2022-10-12 01:12:38 -03:00
|
|
|
This feature can help in some areas:
|
2022-10-12 00:12:42 -03:00
|
|
|
|
|
|
|
1. CGO, as you can build each platform in their target OS and merge later;
|
|
|
|
1. Native packaging and signing for Windows and macOS (more features for this
|
|
|
|
will be added soon);
|
|
|
|
1. Speed up slow builds, by splitting them into multiple workers;
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
You don't really need to set anything up. To get started, run:
|
|
|
|
|
|
|
|
```bash
|
2023-01-30 23:06:46 -03:00
|
|
|
goreleaser release --clean --split
|
|
|
|
GOOS=darwin goreleaser release --clean --split
|
|
|
|
GGOOS=windows goreleaser release --clean --split
|
2022-10-12 00:12:42 -03:00
|
|
|
```
|
|
|
|
|
|
|
|
Note that this step will push your Docker images as well.
|
|
|
|
Docker manifests are not created yet, though.
|
|
|
|
|
2022-10-15 19:27:01 -03:00
|
|
|
- In the first example, it'll build for the current `GOOS` (as returned by
|
|
|
|
`runtime.GOOS`).
|
|
|
|
- In the second, it'll use the informed `GOOS`. This env will also bleed to
|
|
|
|
things like before hooks, so be aware that any `go run` commands ran by
|
|
|
|
GoReleaser there might fail.
|
|
|
|
- The third example uses the informed `GGOOS`, which is used only to filter
|
|
|
|
which targets should be build, and does not affect anything else (as the
|
|
|
|
second option does).
|
2022-10-12 00:12:42 -03:00
|
|
|
|
2022-10-15 19:27:01 -03:00
|
|
|
Those commands will create the needed artifacts for each platform in
|
|
|
|
`dist/$GOOS`.
|
2022-10-12 00:12:42 -03:00
|
|
|
|
2022-10-15 19:27:01 -03:00
|
|
|
You can also specify `GOARCH` and `GGOARCH`, which only take effect if you set
|
|
|
|
`partial.by` to `target`.
|
2022-10-12 00:12:42 -03:00
|
|
|
|
|
|
|
Now, to continue, run:
|
|
|
|
|
|
|
|
```bash
|
2022-10-15 19:27:01 -03:00
|
|
|
goreleaser continue --merge
|
2022-10-12 00:12:42 -03:00
|
|
|
```
|
|
|
|
|
|
|
|
This last step will run some extra things that were not run during the previous
|
|
|
|
step:
|
|
|
|
|
|
|
|
- merge previous contexts and artifacts lists
|
|
|
|
- pull previously built images
|
|
|
|
- create the source archive (if enabled)
|
|
|
|
- checksum all artifacts
|
|
|
|
- sign artifacts (according to configuration)
|
|
|
|
- SBOM artifacts (according to configuration)
|
|
|
|
- run all the publishers
|
|
|
|
- run all the announcers
|
|
|
|
|
2023-03-31 17:38:04 +00:00
|
|
|
!!! warning
|
|
|
|
Please notice that this step will not run anything that the previous step
|
|
|
|
already did.
|
|
|
|
For example, it will not build anything again, nor run any `hooks` you have
|
|
|
|
defined.
|
|
|
|
It will only merge the previous results and publish them.
|
|
|
|
|
2022-10-12 00:12:42 -03:00
|
|
|
You can also run the publishing and announce steps separately:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
goreleaser publish --merge
|
|
|
|
goreleaser announce --merge
|
|
|
|
```
|
|
|
|
|
|
|
|
## Customization
|
|
|
|
|
|
|
|
You can choose by what you want your pipeline to be split by:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
# goreleaser.yaml
|
|
|
|
partial:
|
|
|
|
# By what you want to build the partial things.
|
|
|
|
#
|
|
|
|
# Valid options are `target` and `goos`:
|
|
|
|
# - `target`: `GOOS` + `GOARCH`.
|
|
|
|
# - `goos`: `GOOS` only
|
|
|
|
#
|
|
|
|
# Default: `goos`.
|
|
|
|
by: target
|
|
|
|
```
|
|
|
|
|
2022-10-15 19:27:01 -03:00
|
|
|
## Integration with GitHub Actions
|
|
|
|
|
|
|
|
You can find an example project
|
|
|
|
[here](https://github.com/caarlos0/goreleaser-pro-split-merge-example).
|
|
|
|
Feel free to dive into the workflow and the GoReleaser config.
|