作者:E4b9a6, 创建:2021-01-01, 字数:6288, 已阅:84, 最后更新:2021-01-01
在 GitHub 上,经常可以看到使用GO语言写的程序发布如下程序包
这是基于 Goreleaser 进行的二进制打包, Goreleaser 是一个用于构建和发布Go语言项目的工具,它简化了构建、打包和发布Go应用程序或库的过程
Goreleaser 支持在各种平台上构建二进制文件,并为不同的操作系统和发行版本创建适当的发布包
各个平台的安装方法可参考goreleaser.com - 官方文档
以下以 debian12 为例,实践打包一个GO程序
准备一个 gin 的 go web应用
package main
import (
"net/http"
"github.com/gin-gonic/gin"
)
func main() {
// 创建一个默认的Gin引擎
router := gin.Default()
// 定义一个路由处理函数
router.GET("/", func(c *gin.Context) {
c.JSON(http.StatusOK, gin.H{
"message": "Hello, World!",
})
})
// 启动HTTP服务器,监听在8080端口
router.Run(":8080")
}
安装并启动程序
go mod init gin-demo
go mod tidy
go run main.go
访问一下:8080
端口
curl http://127.0.0.1:8080
{"message":"Hello, World!"}
接下来我们将打包这个程序
安装 Goreleaser
go install github.com/goreleaser/goreleaser@latest
安装完成后,在项目中使用 Goreleaser 初始化项目
goreleaser init
在项目目录中,查看生成的.goreleaser.yaml
文件,如下
version: 1
project_name: gin-demo
before:
hooks:
- go mod tidy
- go generate ./...
builds:
- env:
- CGO_ENABLED=0
goos:
- linux
- windows
- darwin
- freebsd
- openbsd
- netbsd
- solaris
- dragonfly
goarch:
- amd64
- 386
- arm
- arm64
- ppc64
- ppc64le
- mips
- mipsle
- mips64
- mips64le
- s390x
main: ./main.go
archives:
- format: zip
name_template: >-
{{ .ProjectName }}_
{{- title .Os }}_
{{- if eq .Arch "amd64" }}x86_64
{{- else if eq .Arch "386" }}i386
{{- else }}{{ .Arch }}{{ end }}
{{- if .Arm }}v{{ .Arm }}{{ end }}
changelog:
sort: asc
filters:
exclude:
- "^docs:"
- "^test:"
需要关注的参数如下:
project_name
:项目名称builds-goos
:支持的目标操作系统builds-goarch
:支持的目标架构builds-main
:程序入口进行分发打包
goreleaser --snapshot --clean
查看项目目录下的dist
文件夹,里面是打包后的文件,如下:
$ tree
.
├── dist
│ ├── artifacts.json
│ ├── config.yaml
│ ├── gin-demo_0.0.0-SNAPSHOT-none_checksums.txt
│ ├── gin-demo_darwin_amd64_v1
│ │ └── gin-demo
│ ├── gin-demo_darwin_arm64
│ │ └── gin-demo
│ ├── gin-demo_Darwin_arm64.zip
│ ├── gin-demo_Darwin_x86_64.zip
│ ├── gin-demo_dragonfly_amd64_v1
│ │ └── gin-demo
│ ├── gin-demo_Dragonfly_x86_64.zip
│ ├── gin-demo_freebsd_386
│ │ └── gin-demo
│ ├── gin-demo_freebsd_amd64_v1
│ │ └── gin-demo
│ ├── gin-demo_freebsd_arm_6
│ │ └── gin-demo
│ ├── gin-demo_freebsd_arm64
│ │ └── gin-demo
│ ├── gin-demo_Freebsd_arm64.zip
│ ├── gin-demo_Freebsd_armv6.zip
│ ├── gin-demo_Freebsd_i386.zip
│ ├── gin-demo_Freebsd_x86_64.zip
│ ├── gin-demo_linux_386
│ │ └── gin-demo
│ ├── gin-demo_linux_amd64_v1
│ │ └── gin-demo
│ ├── gin-demo_linux_arm_6
│ │ └── gin-demo
│ ├── gin-demo_linux_arm64
│ │ └── gin-demo
│ ├── gin-demo_Linux_arm64.zip
│ ├── gin-demo_Linux_armv6.zip
│ ├── gin-demo_Linux_i386.zip
│ ├── gin-demo_linux_mips64_hardfloat
│ │ └── gin-demo
│ ├── gin-demo_linux_mips64le_hardfloat
│ │ └── gin-demo
│ ├── gin-demo_Linux_mips64le.zip
│ ├── gin-demo_Linux_mips64.zip
│ ├── gin-demo_linux_mips_hardfloat
│ │ └── gin-demo
│ ├── gin-demo_linux_mipsle_hardfloat
│ │ └── gin-demo
│ ├── gin-demo_Linux_mipsle.zip
│ ├── gin-demo_Linux_mips.zip
│ ├── gin-demo_linux_ppc64
│ │ └── gin-demo
│ ├── gin-demo_linux_ppc64le
│ │ └── gin-demo
│ ├── gin-demo_Linux_ppc64le.zip
│ ├── gin-demo_Linux_ppc64.zip
│ ├── gin-demo_linux_s390x
│ │ └── gin-demo
│ ├── gin-demo_Linux_s390x.zip
│ ├── gin-demo_Linux_x86_64.zip
│ ├── gin-demo_netbsd_386
│ │ └── gin-demo
│ ├── gin-demo_netbsd_amd64_v1
│ │ └── gin-demo
│ ├── gin-demo_netbsd_arm_6
│ │ └── gin-demo
│ ├── gin-demo_netbsd_arm64
│ │ └── gin-demo
│ ├── gin-demo_Netbsd_arm64.zip
│ ├── gin-demo_Netbsd_armv6.zip
│ ├── gin-demo_Netbsd_i386.zip
│ ├── gin-demo_Netbsd_x86_64.zip
│ ├── gin-demo_openbsd_386
│ │ └── gin-demo
│ ├── gin-demo_openbsd_amd64_v1
│ │ └── gin-demo
│ ├── gin-demo_openbsd_arm_6
│ │ └── gin-demo
│ ├── gin-demo_openbsd_arm64
│ │ └── gin-demo
│ ├── gin-demo_Openbsd_arm64.zip
│ ├── gin-demo_Openbsd_armv6.zip
│ ├── gin-demo_Openbsd_i386.zip
│ ├── gin-demo_Openbsd_x86_64.zip
│ ├── gin-demo_solaris_amd64_v1
│ │ └── gin-demo
│ ├── gin-demo_Solaris_x86_64.zip
│ ├── gin-demo_windows_386
│ │ └── gin-demo.exe
│ ├── gin-demo_windows_amd64_v1
│ │ └── gin-demo.exe
│ ├── gin-demo_windows_arm_6
│ │ └── gin-demo.exe
│ ├── gin-demo_windows_arm64
│ │ └── gin-demo.exe
│ ├── gin-demo_Windows_arm64.zip
│ ├── gin-demo_Windows_armv6.zip
│ ├── gin-demo_Windows_i386.zip
│ ├── gin-demo_Windows_x86_64.zip
│ └── metadata.json
├── go.mod
├── go.sum
└── main.go
32 directories, 69 files
试试运行:
./dist/gin-demo_linux_amd64_v1/gin-demo
访问一下,看是否可以正常返回:
curl http://127.0.0.1:8080
{"message":"Hello, World!"}
Goreleaser 支持自动化发布,先在 GitHub 上创建一个个人访问令牌(PAT),确保它具有 repo 和 write:packages 权限,然后,将该令牌设置为环境变量:
export GITHUB_TOKEN=your_github_token
然后打标签并自动创建新的发布(就像开头提到的其他go项目一样发布多个客户端)
git tag -a v1.0.0 -m "Release version 1.0.0"
git push origin v1.0.0
goreleaser release
再说说自带的打包方式,假设你在 Linux 上开发,并希望为 Windows 64 位系统编译你的 Go 程序,可以这样做:
env GOOS=windows GOARCH=amd64 go build main.go -o go-gin.exe
GOOS
和 GOARCH
是 Go 编程语言中用于指定目标操作系统和目标架构的环境变量,这些变量在交叉编译(将程序编译为不同平台的可执行文件)时非常有用
GOOS
变量指定目标操作系统,常见的值包括:
linux
:Linuxwindows
:Windowsdarwin
:macOSfreebsd
:FreeBSDopenbsd
:OpenBSDnetbsd
:NetBSDsolaris
:Solarisdragonfly
:DragonFly BSDGOARCH
变量指定目标架构,常见的值包括:
amd64
:64位 x86386
:32位 x86arm
:32位 ARMarm64
:64位 ARMppc64
:64位 PowerPCppc64le
:64位 Little Endian PowerPCmips
:32位 MIPSmipsle
:32位 Little Endian MIPSmips64
:64位 MIPSmips64le
:64位 Little Endian MIPSs390x
:64位 IBM Z 系列