>  기사  >  백엔드 개발  >  一个不一样的 Go 项目版本号管理方案

一个不一样的 Go 项目版本号管理方案

Go语言进阶学习
Go语言进阶学习앞으로
2023-07-24 16:07:551025검색
버전 정보 관리는 프로젝트 개발 시 고려해야 할 문제입니다. 특히 다양한 유형의 오픈 소스 소프트웨어에서 중요한 기능적 특징은 버전 번호에 묶여 있어야 합니다. 버전 번호를 통해 사용자는 프로그램이 어떤 기능을 제공하는지 알 수 있습니다.

그럼 프로젝트에 버전 번호를 추가하는 방법은 무엇인가요? 많은 사람들이 하드코딩, 즉 버전 번호를 소스 코드나 구성 파일에 직접 쓰고, 기능이 업그레이드될 때마다 버전 번호를 수정하는 방식을 사용했어야 합니다. 이 방법은 분명히 실현 가능하지만 오류가 발생하기 쉽습니다. 첫째, 버전을 출시할 때 버전 번호를 업데이트하는 것을 잊어버리기 쉽습니다. 둘째, 여러 분기 코드가 병합되면 혼란이 발생할 수 있습니다.

다음은 다른 관리 계획을 알려 드리겠습니다.

ldflags -X 변수 전송

go 링커 링커는 바이너리 파일을 조립하는 도구입니다. go 빌드 명령을 실행할 때 <code style='font-size: 14px;overflow-wrap: break-word;padding: 2px 4px;border-radius: 4px;margin-right: 2px;margin-left: 2px;font-family: "Operator Mono", Consolas, Monaco, Menlo, monospace;word-break: break-all;background: rgba(14, 210, 247, 0.15);'><span style="font-size: 15px;">--ldflags</span> 标志设定链接器参数,使用以下语句可查看链接器可选参数。

go build --ldflags="--help"

参数很多,但我们感兴趣的是 <span style="font-size: 15px;">-X</span>

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

<span style="font-size: 15px;">-X</span>--ldflags 플래그는 링커 매개변수를 설정합니다. 링커 선택적 매개변수를 보려면 다음 명령문을 사용하세요.

🎜
$ mkdir versionDemo 
$ cd versionDemo/
$ go mod init versiondemo
go: creating new go.mod: module versiondemo
$ touch main.go
🎜🎜여러 매개변수가 있지만 우리가 관심을 갖는 매개변수는 🎜🎜-X 🎜🎜
package main

import (
 "fmt"
)

var (
 version = "0.0.1"
)

func main() {
 fmt.Println("version: ", version)
}
🎜🎜-X🎜 code>🎜 매개 변수는 변수 값을 수정하는 데 사용되는 importpath.name=value를 지정합니다. 그 중 importpath는 패키지 가져오기 경로를 나타내고, name은 프로그램 내의 변수 이름, value는 우리가 설정하려는 변수 값을 나타냅니다. 🎜🎜<p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">下面,我们通过示例项目来具体感受一下。</span></p><pre class="brush:php;toolbar:false;">$ mkdir versionDemo $ cd versionDemo/ $ go mod init versiondemo go: creating new go.mod: module versiondemo $ touch main.go</pre><p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">在 main 函数中,我们打印 version 值。</span></p><pre class="brush:php;toolbar:false;">package main import ( &quot;fmt&quot; ) var ( version = &quot;0.0.1&quot; ) func main() { fmt.Println(&quot;version: &quot;, version) }</pre><p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">如果正常编译执行程序,将得到以下结果</span></p><pre class="brush:php;toolbar:false;"> $ go build -o main &amp;&amp; ./main version: 0.0.1</pre><p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">此时,我们指定 --ldflags  的 -X 参数重新编译执行</span></p><pre class="brush:php;toolbar:false;">$ go build -o main --ldflags=&quot;-X &amp;#39;main.version=client-0.0.2&amp;#39;&quot; &amp;&amp; ./main version: client-0.0.2</pre><p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">可以看到 version 参数值已经被改变。</span></p> <h2 data-tool="mdnice编辑器" style="margin-top: 30px;margin-bottom: 15px;font-weight: bold;font-size: 22px;border-bottom: 4px solid rgb(160, 249, 176);display: flex;"><span style="width: 100%;display: flex;color: rgba(160, 249, 176);padding: 0.5rem 1rem;border-top-left-radius: 4px;border-top-right-radius: 4px;background: #181a21 !important;">添加 git 信息</span></h2> <p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">开发中需要使用 git 工具,本文讨论的版本管理,也经常与 git tag 挂钩。那其实有更酷的操作:我们可以在构建期间,通过 git commit 信息自动填充版本号。</span></p> <p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">我们基于上文项目目录,添加 git commit 信息。</span></p><pre class="brush:php;toolbar:false;">$ git init $ git add . $ git commit -m &quot;initial commit&quot;</pre><p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">通过以下命令,可拿到 git commit 的 hash 值</span></p><pre class="brush:php;toolbar:false;"> $ git rev-parse HEAD 46dab0ddb6ba20445c2c1f047575e25d3aad1a27</pre><p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">该值较长,我们可以添加 --short 选项获取短 hash 值。</span></p><pre class="brush:php;toolbar:false;">$ git rev-parse --short HEAD 46dab0d</pre><p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">此时,通过指定 --ldflags  的 -X 参数,将 version 值替换成 git commit 的哈希值。这样,我们成功地将项目版本与 git 信息绑定在了一起。</span></p><pre class="brush:php;toolbar:false;">$ go build -o main --ldflags=&quot;-X &amp;#39;main.version=$(git rev-parse --short HEAD)&amp;#39;&quot; &amp;&amp; ./main version: 46dab0d</pre><h2 data-tool="mdnice编辑器" style="margin-top: 30px;margin-bottom: 15px;font-weight: bold;font-size: 22px;border-bottom: 4px solid rgb(160, 249, 176);display: flex;"><span style="width: 100%;display: flex;color: rgba(160, 249, 176);padding: 0.5rem 1rem;border-top-left-radius: 4px;border-top-right-radius: 4px;background: #181a21 !important;">总结</span></h2> <p data-tool="mdnice编辑器" style="padding-top: 8px;padding-bottom: 8px;line-height: 26px;font-size: 17px;word-spacing: 3px;letter-spacing: 1px;"><span style="font-size: 15px;">本文介绍了一种如何通过 ldflags  -X 变量传递的方式。使用这种方式我们可以在构建时轻松设定一些元信息,例如本文示例的程序版本信息。而这种构建的动作不应该手动去执行,而是放入到  CI/CD 流程中,让整个过程变得更加丝滑。</span></p>

위 내용은 一个不一样的 Go 项目版本号管理方案의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 Go语言进阶学习에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
이전 기사:다음 기사: