Skip to main content

01.mod的使用

modgo的一个依赖管理工。之前1.11之前的go版本是没有这个模块管理,由于所以依赖都放在$GOPATH/src会造成项目之间版本不一致,而可能出错。 有使用前要把环境变量修改下,来启动模块管理:

  $ export GO111MODULE=on # 启动后,项目的依赖是根据go.mod的配置来加载的。也可以脱离$GOPATH目录才能创建项目的情况。
$ export GO111MODULE=off # 反之关闭
$ export GO111MODULE=auto # 这个是自动识别,如果又想用模块管理又想让之前不是模块管理的应用也能跑起来,可以先用这个

选择好自己需要的模式后,把它写进bashzsh的配置中,让它默认生效, 如:


$ echo "export GO111MODULE=<你的选择>" >> ~/.zshrc #写入zsh配置
$ echo "export GO111MODULE=<你的选择>" >> ~/.bashrc #写入bash配置

而这些依赖会保存在$GOPATH/pkg/mod目录下。

命令说明
go mod init生成go.mod文件
go mod download下载go.mod声明的依赖
go mod tidy整理下依赖, 如删除没用的依赖
go mod graph查看依赖结构
go mod edit编辑go.mod文件
go mod vendor把依赖导入到项目的vendor目录中
go mod verify校验模块是否被篡改
go mod why查看为什么需要依赖模块
go clean -modcache清除缓存