我们可能需要类似 go get –u …. 这样的方式来实现我们的应用,这时候我们无法简单地使用 flag.Parse 了,而是要用 FlagSet 了, 使用例子如下:
package main
import (
"flag"
"log"
"os"
)
var ()
func main() {
// 读取命令参数,注意,这里根据执行任务的不同,参数也不一样
// 技术参考:
// http://stackoverflow.com/questions/24504024/defining-independent-flagsets-in-golang
// http://play.golang.org/p/eaEEx_EReX
if len(os.Args) <= 1 {
log.Println("请输入命令,支持的命令: esb、web、host!")
os.Exit(-1)
}
log.Println(os.Args[1])
cmd := os.Args[1]
// esb 客户端工具
fesb := flag.NewFlagSet("fesb", flag.ContinueOnError)
consumer := fesb.Int("c", 0, "ESB 关系中过滤消费者的编号,不输代表全部。")
provider := fesb.Int("p", 0, "ESB 关系中过滤生产者的编号,不输代表全部。")
dependType := fesb.String("t", "cache", "ESB关系依赖的类型,默认来自线上的缓存,可选项:config (数据库的配置),cache(线上调用的缓存)")
// web 站点
fweb := flag.NewFlagSet("fweb", flag.ContinueOnError)
webPort := fweb.Int("p", 81, "WEB 站点使用的端口号。")
// 修改host文件方式
fhost := flag.NewFlagSet("fhost", flag.ContinueOnError)
aaa := fhost.Bool("b", false, "test 参数!")
switch cmd {
case "esb":
err := fesb.Parse(os.Args[2:])
if err != nil {
log.Println("esb 参数类型错误,", err)
os.Exit(-1)
}
log.Println("dependType:", *dependType)
log.Println("consumer:", *consumer)
log.Println("provider:", *provider)
case "web":
err := fweb.Parse(os.Args[2:])
if err != nil {
log.Println("web 参数类型错误,", err)
os.Exit(-1)
}
log.Println("webPort:", *webPort)
case "host":
err := fhost.Parse(os.Args[2:])
if err != nil {
log.Println("host 参数类型错误,", err)
os.Exit(-1)
}
log.Println("aaa:", *aaa)
}
}
参考资料:
http://play.golang.org/p/eaEEx_EReX
http://stackoverflow.com/questions/24504024/defining-independent-flagsets-in-golang
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示