1. 参数绑定与交叉编译
- 使用 https://github.com/spf13/cobra 实现命令工具
- 命令具有以下参数
--name
姓名--age
年龄
- 如果年龄为空, 默认为 20 岁。
- 完成交叉编译脚本, 编译其他平台的二进制文件
-rwxr-xr-x 1 devopscamp staff 4220672 Jan 13 15:35 greeting-darwin-amd64
-rwxr-xr-x 1 devopscamp staff 4203442 Jan 13 15:35 greeting-darwin-arm64
-rwxr-xr-x 1 devopscamp staff 4215010 Jan 13 15:35 greeting-linux-amd64
-rwxr-xr-x 1 devopscamp staff 4157892 Jan 13 15:35 greeting-linux-arm64
- 执行输出效果如下
$ ./out/greeting-darwin-arm64
你好, 今年 20 岁
$ ./out/greeting-darwin-arm64 --age 30 --name zhangsan
zhangsan 你好, 今年 30 岁
$ go get -u github.com/spf13/cobra
var root = &cobra.Command{
Use: "greeting", // 命令名字
Short: "打招呼", // 短介绍
Run: func(cmd *cobra.Command, args []string) { // 运行函数
greeting(name, age)
},
}
- 定义了变量作为参数接受者。
- 使用 init 函数, 在程序初始化的时候, 传递参数值。
- 参数接受者 指针类型
- 参数名称, 字符串类型
- 短参数名称, 字符串类型, 但只接受一个参数
- 默认值, 具体类型
- 参数描述, 字符串类型
var (
name = ""
age = 0
)
func init() {
root.Flags().StringVarP(&name, "name", "", "", "姓名")
root.Flags().IntVarP(&age, "age", "", 20, "年龄")
}
- greeting 是程序实际执行逻辑, 及执行逻辑入口。
- 在 root 的 Run 中调用 执行逻辑入口。
- 在 main 中调用 root 的执行函数 Execute()
func greeting(name string, age int) {
fmt.Printf("%s 你好, 今年 %d 岁\n", name, age)
}
var root = &cobra.Command{
Use: "greeting",
Short: "打招呼",
Run: func(cmd *cobra.Command, args []string) {
greeting(name, age) // 2. root 命令调用 greeting 业务
},
}
func main() {
err := root.Execute() // 3. main 调用 root 命令
if err != nil {
log.Fatal(err)
}
}
- 使用
GOOS
和GOARCH
设置环境变量命令。 - 使用
build
命令, 使用进行 当前系统环境 的编译- 并且编译文件命名包含系统信息。
- 使用
buildx
命令, 实现 交叉编译 - 使用
clean
命令清空编译结果。
## 默认变量, 获取当前 go 的环境变量
GOOS ?= $(shell go env GOOS)
GOARCH ?= $(shell go env GOARCH)
## build 在指定环境变异
build:
go build -o out/greeting-$(GOOS)-$(GOARCH) .
## 通过指定环境变量, 执行交叉编译
buildx:
GOOS=linux GOARCH=amd64 make build
GOOS=linux GOARCH=arm64 make build
GOOS=darwin GOARCH=amd64 make build
GOOS=darwin GOARCH=arm64 make build
## 清理编译结果
clean:
rm -rf out/
一个最基本命令结构就这样完成了, 是不是很简单?