1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-24 04:16:27 +02:00
goreleaser/www/docs/install.md
Carlos A Becker 40b38fbdc9
docs: sync docs
Signed-off-by: Carlos A Becker <caarlos0@gmail.com>
2021-06-21 02:20:34 +00:00

4.3 KiB

Install

There are two GoReleaser distributions: OSS and Pro.

You can install the pre-compiled binary (in several different ways), use Docker or compile from source (when on OSS).

Here are the steps for each of them:

Install the pre-compiled binary

homebrew tap

oss

brew install goreleaser/tap/goreleaser

pro

brew install goreleaser/tap/goreleaser-pro

homebrew

OSS-only, may not be the latest version.

brew install goreleaser

snapcraft

OSS only.

sudo snap install --classic goreleaser

scoop

oss

scoop bucket add goreleaser https://github.com/goreleaser/scoop-bucket.git
scoop install goreleaser

pro

scoop bucket add goreleaser https://github.com/goreleaser/scoop-bucket.git
scoop install goreleaser-pro

apt

setup repository

echo 'deb [trusted=yes] https://apt.fury.io/goreleaser/ /' | sudo tee /etc/apt/sources.list.d/goreleaser.list
sudo apt update

oss

sudo apt install goreleaser

pro

sudo apt install goreleaser-pro

yum

setup repository

echo '[goreleaser]
name=GoReleaser
baseurl=https://yum.fury.io/goreleaser/
enabled=1
gpgcheck=0' | sudo tee /etc/yum.repos.d/goreleaser.repo

oss

sudo yum install goreleaser

pro

sudo yum install goreleaser-pro

deb, rpm and apk packages

Download the .deb, .rpm or .apk from the OSS or Pro releases pages and install them with the appropriate tools.

shell script

OSS only.

curl -sfL https://install.goreleaser.com/github.com/goreleaser/goreleaser.sh | sh

go install

OSS only.

go install github.com/goreleaser/goreleaser

manually

Download the pre-compiled binaries from the OSS or Pro releases pages and copy to the desired location.

Running with Docker

You can also use it within a Docker container. To do that, you'll need to execute something more-or-less like the examples bellow.

oss

Registries:

Example usage:

docker run --rm --privileged \
  -v $PWD:/go/src/github.com/user/repo \
  -v /var/run/docker.sock:/var/run/docker.sock \
  -w /go/src/github.com/user/repo \
  -e GITHUB_TOKEN \
  -e DOCKER_USERNAME \
  -e DOCKER_PASSWORD \
  -e DOCKER_REGISTRY \
  goreleaser/goreleaser release

pro

Registries:

Example usage:

docker run --rm --privileged \
  -v $PWD:/go/src/github.com/user/repo \
  -v /var/run/docker.sock:/var/run/docker.sock \
  -w /go/src/github.com/user/repo \
  -e GITHUB_TOKEN \
  -e DOCKER_USERNAME \
  -e DOCKER_PASSWORD \
  -e DOCKER_REGISTRY \
  -e GORELEASER_KEY \
  goreleaser/goreleaser-pro release

!!! info Currently, the provided docker image does not support the generation of snapcraft packages.

Note that the image will almost always have the last stable Go version.

The DOCKER_REGISTRY environment variable can be left empty when you are releasing to the public docker registry.

If you need more things, you are encouraged to keep your own image. You can always use GoReleaser's own Dockerfile as an example though and iterate from that.

Compiling from source

Here you have two options:

If you want to contribute to the project, please follow the steps on our contributing guide.

If you just want to build from source for whatever reason, follow these steps:

clone:

git clone https://github.com/goreleaser/goreleaser
cd goreleaser

get the dependencies:

go mod tidy

build:

go build -o goreleaser .

verify it works:

./goreleaser --version