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

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

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
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就算配置好了,我们可以先编译一下试试

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

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

1
2
3
4
5
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,如果没有的话要先去这里申请一个

1
export GITHUB_TOKEN='YOUR_TOKEN'

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

1
goreleaser

release


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