Golang 依赖管理工具 Modules使用教程

1、首先安装好golang开发环境

安装开发环境这里不做介绍说明了;

2、开始使用Modules

2.1 配置环境变量

Modules 默认不是启用状态;我们可以通过设置环境变量GO111MODULE开启或禁用;GO111MODULE变量有三个可选值off、on、auto,默认值是 auto。

1、off。关闭支持,go 会从GOPATH和vendor文件夹寻找包。
2、on。开启支持,go 会忽略 GOPATH 和 vendor 文件夹,只根据go.mod下载依赖。
3、auto。当项目在$GOPATH/src外,且项目根目录有go.mod文件时,开启模块支持。

Golang 依赖管理工具 Modules使用教程_第1张图片

2.2 初始化项目或模块
go mod init test

执行完改指令会在项目根目录生成go.mod 文件
Golang 依赖管理工具 Modules使用教程_第2张图片
我们打开一下go.mod 文件

 module test// 模块名称

go 1.12 	 // golang 版本号
2.3 go mod tidy

执行go mod tidy 指令自动更新依赖关系。
Golang 依赖管理工具 Modules使用教程_第3张图片
此时项目根目录又生成一个新文件go.sum 文件。
Golang 依赖管理工具 Modules使用教程_第4张图片
go.sum 文件的内容是我们直接引用的package和它自身需要的版本记录,go modules就是根据这些去找到需要的packages的。

2.4 go build

还有个一个值得注意的新增编译项“-mod”,它有如下的可选值.

go build -mod=readonly

readonly:在这个模式下任何会导致依赖关系变动的情况都将导致build失败,前面提到过build能查找并更新依赖关系,使用这个选项可以检查依赖关系的变动。

go build -mod=vendor

vendor:忽略cache里的包,只使用vendor目录里的版本。

2.5 下载依赖报错

Golang 无法下载依赖解决方案 unrecognized import path "golang.org/x/net

go: golang.org/x/[email protected]: unrecognized import path "golang.org/x/net" (https fetch: Get https://golang.org/x/net?go-get=1: dial tcp 216.239.37.1:443: i/o timeout)
go: golang.org/x/[email protected]: unrecognized import path "golang.org/x/net" (https fetch: Get https://golang.org/x/net?go-get=1: dial tcp 216.239.37.1:443: i/o timeout)
go: error loading module requirements

解决方法:
Modules 新增了GOPROXY 环境变量,该变量下载源代码时会通过此环境变量设置的代理地址,不再使用以前的直接从代码库下载。我们可以把GOPROXY 变量设置为https://goproxy.io公用代理服务。
在这里插入图片描述

你可能感兴趣的:(go)