golang編譯時經過ldflags給包內變量賦值,實現打印版本號及commit

不少命令行程序均可以經過version參數輸出版本信息,commit,操做系統等信息。下面介紹一種方法實現golang編譯的命令行程序打印版本號。linux

docker打印的版本信息:git

$ ~ docker version
Client: Docker Engine - Community
 Version:           18.09.2
 API version:       1.39
 Go version:        go1.10.8
 Git commit:        6247962
 Built:             Sun Feb 10 04:12:39 2019
 OS/Arch:           darwin/amd64
 Experimental:      false

Server: Docker Engine - Community
 Engine:
  Version:          18.09.2
  API version:      1.39 (minimum version 1.12)
  Go version:       go1.10.6
  Git commit:       6247962
  Built:            Sun Feb 10 04:13:06 2019
  OS/Arch:          linux/amd64
  Experimental:     false

實現方式是利用go build的一個參數-ldflags。輸入go help build,能夠看到一個配置項:golang

-ldflags 'flag list' arguments to pass on each go tool link invocation.

這個參數是用來設置go link(靜態連接)的一些參數,具體有哪些參數能夠經過go tool link --help查看。docker

其中-X參數能夠在編譯時給包內的變量賦值,而後咱們利用flag包設置version參數就能實現打印版本號了。bash

main.go:ui

package main

import (
    "flag"
    "log"
    "os"
)

var (
    Version   string
    Branch    string
    Commit    string
    BuildTime string
    lowercase string // 小寫也能夠
)

func main() {
    versionFlag := flag.Bool("version", false, "print the version")
    flag.Parse()

    if *versionFlag {
        log.Printf("Version: %s\n", Version)
        log.Printf("Branch: %s\n", Branch)
        log.Printf("Commit: %s\n", Commit)
        log.Printf("BuildTime: %s\n", BuildTime)
        log.Printf("lowercase: %s\n", lowercase)
        os.Exit(0)
    }

    log.Println("run main.go")
}

打包腳本:操作系統

#!/usr/bin/env bash

prog=xxx
version=1.1.0
lowercase=ok

# 交叉編譯
# CGO_ENABLED=0 GOOS=linux GOARCH=amd64
go build -ldflags "\
-X main.Version=$version \
-X main.Branch=`git rev-parse --abbrev-ref HEAD` \
-X main.Commit=`git rev-parse HEAD` \
-X main.BuildTime=`date -u '+%Y-%m-%d_%H:%M:%S'` \
-X main.lowercase=$lowercase \
" -v -o $prog main.go

最終效果:命令行

$ ./xxx -version
2019/04/11 00:59:08 Version: 1.1.0
2019/04/11 00:59:08 Branch: master
2019/04/11 00:59:08 Commit: 29921d9df18543693321e2109ea36462dbb346d3
2019/04/11 00:59:08 BuildTime: 2019-04-10_16:59:07
2019/04/11 00:59:08 lowercase: ok
相關文章
相關標籤/搜索