Modules是Go 1.11中新增的实验性功能,是一种新型的包管理工具。使用前确保go version在1.11以上
1.windows中-cmd下执行go env,查看环境变量
运行go env -w GO111MODULE=on
运行go env -w GOPROXY=https://goproxy.cn,direct //使用代理
注意 https://goproxy.io 也可替换成阿里云的 https://mirrors.aliyun.com/goproxy
备注:
配置环境变量 GO111MODULE:有三个可选值: off、 on、 auto,默认值是 auto。
1.GO111MODULE=off,无模块支持,go会从 GOPATH 和 vendor 文件夹寻找包。
2.GO111MODULE=on,模块支持,go会忽略 GOPATH 和 vendor 文件夹,只根据 go.mod下载依赖。
3.GO111MODULE=auto,在 $GOPATH/src外面且根目录有 go.mod文件时,开启模块支持
2.go 使用的基本命令
go mod init // 在当前目录初始化mod
go mod download //下载依赖包 下载modules到本地cache 包在 GOPATH/pkg/mod 目录中,而且是只读文件
go mod vendor //将依赖复制到vendor下 ,会生成vendor文件夹
该文件夹下将会放置你go.mod文件描述的依赖包,文件夹下同时还有一个文件modules.txt
go mod verify //验证依赖项是否达到预期的目的
如果所有的模块都没有被修改过,那么执行这条命令之后,会打印all modules verified
go mod tidy //添加缺失的模块以及移除无用的模块 执行后会生成go.sum文件
go mod tidy -v //可以将执行的信息,即删除和添加的包打印到命令行
go mod graph //打印模块依赖图
go mod why //解释为什么需要依赖
go clean -modcache //清除mod下载的包
go mod edit -replace==github.com/mojocn/base64Captcha@v1.3.5=github.com/mojocn/base64Captcha@v1.3.1 # 修改指定包版本
3.go.mod文件内容解释
go.mod 提供了module, require、replace和exclude四个命令
module语句指定包的名字(路径)
require语句指定的依赖项模块
replace语句可以替换依赖项模块
exclude语句可以忽略依赖项模块
4.在非gopath目录下创建go项目执行go mod init报错: cannot determine module path for source directory xxxxxxx (outside GOPATH, module path must be specified) .解决:go mod init xxx(项目名)