golangci-lint

Install

CI installation

Most installations of golangci-lint are performed for CI.

GitHub Actions

We recommend using our GitHub Action for running golangci-lint in CI for GitHub projects. It's fast and uses smart caching inside, and it can be much faster than the simple binary installation.

Also, the action creates GitHub annotations for found issues: you don't need to dig into build log to see found by golangci-lint issues:

GitHub annotations of the action

Other CI

It's important to have reproducible CI: don't start to fail all builds at the same time. With golangci-lint this can happen if you use option --enable-all and a new linter is added or even without --enable-all when one upstream linter is upgraded.

IMPORTANT: It's highly recommended installing a specific version of golangci-lint available on the releases page.

Here is the recommended way to install golangci-lint v1.57.2:

# binary will be $(go env GOPATH)/bin/golangci-lint
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.57.2
# or install it into ./bin/
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.57.2
# In alpine linux (as it does not come with curl by default)
wget -O- -nv https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s v1.57.2
golangci-lint --version

It is advised that you periodically update the version of golangci-lint as the project is under active development and is constantly being improved. For any problems with golangci-lint, check out recent GitHub issues and update if needed.

Local Installation

Binaries

# binary will be $(go env GOPATH)/bin/golangci-lint
curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.57.2
golangci-lint --version

On Windows, you can run the above commands with Git Bash, which comes with Git for Windows.

Docker

docker run --rm -v $(pwd):/app -w /app golangci/golangci-lint:v1.57.2 golangci-lint run -v

Preserving cache between consecutive runs:

docker run --rm -v $(pwd):/app -v ~/.cache/golangci-lint/v1.57.2:/root/.cache -w /app golangci/golangci-lint:v1.57.2 golangci-lint run -v

Colored output:

docker run -t --rm -v $(pwd):/app -w /app golangci/golangci-lint:v1.57.2 golangci-lint run -v

macOS

Note: brew can use a non-expected version of Go to build the binary, so we recommend either using our binaries or be sure of the version of Go used to build.

You can install a binary release on macOS using brew:

brew install golangci-lint
brew upgrade golangci-lint

Note: Previously we used a homebrew tap. We recommend using official formula instead of the tap, but sometimes the most recent release isn't immediately available via homebrew core due to manual updates that need to occur from homebrew core maintainers. In this case, the tap formula, which is updated automatically, can be used to install the latest version of golangci-lint:

brew tap golangci/tap
brew install golangci/tap/golangci-lint

It can also be installed through macports The macports installation mode is community driven, and not officially maintained by golangci team.

sudo port install golangci-lint

Windows

You can install a binary on Windows using chocolatey:

choco install golangci-lint

Install from Source

Note: such go install/go get installation aren't guaranteed to work. We recommend using binary installation.

Why?

go install/go get installation isn't recommended because of the following points:

  1. Some users use -u flag for go get, which upgrades our dependencies. Resulting configuration wasn't tested and isn't guaranteed to work.
  2. go.mod replacement directive doesn't apply. It means a user will be using patched version of golangci-lint if we use such replacements.
  3. We've encountered a lot of issues with Go modules hashes.
  4. It allows installation from master branch which can't be considered stable.
  5. It's slower than binary installation.
go install github.com/golangci/golangci-lint/cmd/golangci-lint@v1.57.2

Next

Quick Start: how to use golangci-lint.

Edit this page on GitHub