1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00

99 lines
2.7 KiB
Markdown
Raw Normal View History

# Splitting and Merging builds
2022-10-12 01:12:38 -03:00
GoReleaser can also split and merge builds.
> Since: v1.12 (pro)
2022-10-12 01:04:51 -03:00
!!! success "GoReleaser Pro"
This subcommand is a [GoReleaser Pro feature](https://goreleaser.com/pro/).
2022-10-12 01:12:38 -03:00
This feature can help in some areas:
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
goreleaser release --clean --split
GOOS=darwin goreleaser release --clean --split
GGOOS=windows goreleaser release --clean --split
```
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-15 19:27:01 -03:00
Those commands will create the needed artifacts for each platform in
`dist/$GOOS`.
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`.
Now, to continue, run:
```bash
2022-10-15 19:27:01 -03:00
goreleaser continue --merge
```
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
!!! 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.
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.