GoReleaser 使用教程

杂谈 | 共 1677 字 | 2018/4/15 发表 | 2018/4/24 更新

众所周知,go 语言是支持跨平台编译的,如果每次编译发布都手动操作的话太麻烦了。GoReleaser这个工具就可以帮助我们编译和发布,配置好后每次发布时只需一行命令就直接编译并发布了,显著地提高了生产力 🤣

首先要配置一下goreleaser.yml,这里用我的WebSocks作为示例。我这个项目比较特殊,有 server 与 local 两个 main 函数,所以 binary 要两个都编译。

builds:
  - binary: websocks-local
    main: ./cmd/websocks-local/main.go
    goos:
      - windows
      - darwin
      - linux
      - freebsd
    goarch:
      - amd64
      - 386
      - arm
      - arm64
    goarm:
      - 6
      - 7
  - binary: websocks-server
    main: ./cmd/websocks-server/main.go
    goos:
      - windows
      - darwin
      - linux
      - freebsd
    goarch:
      - amd64
      - 386
      - arm
      - arm64
    goarm:
      - 6
      - 7
archive:
  name_template: '{{ .ProjectName }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ .Arm }}{{ end }}'
  replacements:
    darwin: Darwin
    linux: Linux
    windows: Windows
    386: i386
    amd64: x86_64
  format_overrides:
    - goos: windows
      format: zip

配置好了以后要记得往.gitignore里加上一行'dist',因为 goreleaser 会默认把编译编译好的文件输出到 dist 文件夹。

这样 goreleaser 就算配置好了,我们可以先编译一下试试

goreleaser --skip-validate --skip-publish --snapshot

没什么问题的话就把改动添加到 git 里面,push 到 github

git add .
git commit -S -m "add goreleaser"
git tag -a v0.1.0 -m "First release"
git push origin master
git push origin v0.1.0

在 release 之前,我们要先添加一下 github 的 token,如果没有的话要先去这里申请一个

export GITHUB_TOKEN='YOUR_TOKEN'

至此,全部工作都搞定了,可以一键起飞了

goreleaser

github-release


其实还可以配合 CI 使用效率更佳