Go 项目版本号管理方案之ldflags -X 变量传递

go 链接器 Linker 是组装二进制文件的工具,我们在执行go build命令时,可以通过--ldflags标志设定链接器参数,使用以下语句可查看链接器可选参数。
go build --ldflags="--help"
参数很多,但我们感兴趣的是-X

$ go build --ldflags="--help"
usage: link [options] main.o
...
  -X definition
     add string value definition of the form importpath.name=value
...

-X参数,指定importpath.name=value,用于修改变量值。其中importpath表示包导入路径,name是程序中的变量名,value代表我们想要设定的变量值。
下面,我们通过示例项目来具体感受一下。

$ mkdir versionDemo 
$ cd versionDemo/
$ go mod init versiondemo
go: creating new go.mod: module versiondemo
$ touch main.go

在 main 函数中,我们打印 version 值。

package main

import (
 "fmt"
)

var (
 version = "0.0.1"
)

func main() {
 fmt.Println("version: ", version)
}

如果正常编译执行程序,将得到以下结果

$ go build -o main && ./main
version:  0.0.1

此时,我们指定--ldflags -X参数重新编译执行

$ go build -o main --ldflags="-X 'main.version=client-0.0.2'" && ./main
version:  client-0.0.2

可以看到 version 参数值已经被改变。

添加 git 信息

开发中需要使用 git 工具,本文讨论的版本管理,也经常与 git tag 挂钩。那其实有更酷的操作:我们可以在构建期间,通过git commit信息自动填充版本号。
我们基于上文项目目录,添加git commit信息。

$ git init
$ git add .
$ git commit -m "initial commit"

通过以下命令,可拿到 git commit 的 hash 值

 $ git rev-parse HEAD
154d0e19b63567fe85f713fd441f3f6a82a7aa7d

该值较长,我们可以添加--short选项获取短 hash 值。

$ git rev-parse --short HEAD
154d0e1

此时,通过指定--ldflags-X参数,将version值替换成git commit的哈希值。这样,我们成功地将项目版本与 git 信息绑定在了一起。

$ go build -o main --ldflags="-X 'main.version=$(git rev-parse --short HEAD)'" && ./main
version:  154d0e1

Makefile学习

VERSION = $$(git describe --abbrev=0 --tags)
COMMIT_TAG = $$(git tag --points-at HEAD)
VERSION_DATE = $$(git log -1 --pretty='%ad' --date=format:'%Y-%m-%d' $(VERSION))
COMMIT_REV = $$(git rev-list -n 1 $(VERSION))
MAINTAINER = "Memory"

all: build

build:
    go build -ldflags "-X config/config.version=$(VERSION)" -o bin/doGo main.go && upx bin/doGo

mac
    env GOARCH=amd64 go build -ldflags "-s -w -X config/config.version=$(VERSION)" -o bin/macos/doGo && upx bin/macos/doGo

linux
    env GOOS=linux GOARCH=amd64 go build -ldflags "-s -w -X config/config.version=$(VERSION)" -o bin/linux/doGo && upx bin/linux/doGo

docker-build:
    docker build --build-arg VERSION=$(VERSION) --build-arg MAINTAINER=$(MAINTAINER) -t memory/doGo .

标签: Go

相关文章

Go并发编程与调度器及并发模式详解

Go语言以其简洁的语法和强大的并发能力,成为现代网络编程和微服务架构的热门选择。本文将深入探讨Go的并发编程模型,调度器的工作机制,以及多种并发模式的实现和应用,帮助开发者更好地理解并发编程的设...

Go语言中sync.Pool详解

sync.Pool 是 Go 语言标准库中的一个数据结构,用于提供高效的对象池。它的主要作用是缓存临时对象,以减少内存分配和垃圾回收的开销。sync.Pool 特别适合用于存储短生命周期的对象,...

Go 中的并发 Map:使用sync.Map及其他实现方法

在 Go 语言中,并发编程是一个核心特性,能够高效地处理多个 goroutine 的并发执行。为了安全地在多个 goroutine 中共享数据,Go 提供了多种同步机制,其中之一就是线程安全的 ...

Go语言中的单例模式及其实现sync.Once

在软件开发中,单例模式是一种确保一个类只有一个实例的设计模式。在 Go 语言中,sync.Once 是实现单例模式的强大工具,它确保某个操作只被执行一次,适合在多线程环境中使用。本篇文章将详细介...

详解Go条件变量cond的使用

在 Go 语言中,条件变量(sync.Cond)是一种用于实现线程间同步的工具。它允许一个或多个 goroutine 等待某个条件的发生。条件变量通常与互斥锁(sync.Mutex)结合使用,以...

Go语言任务编排好帮手WaitGroup

在并发编程中,任务的协调与管理至关重要。在Go语言中,sync.WaitGroup是一个非常实用的工具,能够帮助我们等待一组任务完成。本文将详细讲解WaitGroup的使用方法、实现原理、使用陷...

Go 语言中的读写锁RWMutex详解

在现代并发编程中,如何高效、安全地管理共享资源是一项重要的挑战。Go 语言的 sync 包提供了多种同步原语,其中 RWMutex(读写锁)特别适合于读多写少的场景。本文将深入探讨 RWMute...

图片Base64编码

CSR生成

图片无损放大

图片占位符

Excel拆分文件