Go Module(一)
这世上太多的人,宁愿吃生活苦,也不愿吃自律的苦。大概是因为生活的苦,躺着就来了,而自律的苦,得自己去找。但只有吃得下自律的苦,才有成功的自由,没有一种成功是走得了捷径的,通向真正成功的唯一道路只有自律。越成功,越自律。越自律,越成功。
GO111MODULE
Go 1.1
包含了对Go Modules
的预支持,包括调整后的go get
命令。后续版本总GOPATH
和老的go get
可能会被官方移除。
在Go Modules
中支持了一个临时环境变量:GO111MODULE
,可以赋值为off
、on
或auto
。
- 值为
off
,表示不支持Go Modules
模式,Go
仍然在vendor
和GoPATH
路径下查找依赖; - 值为
on
,表示当前明确使用Go Modules
,Go
不再去GOPATH
下查找任何依赖; - 值为
auto
或未设置,表示是否启用Go Modules
依赖当前的目录情况,当编译的项目在GoPATH/src
之外,或者当前目录或子目录本身包含go.mod
文件,则启用Go Modules
模式。
Defining a module
module
通过源码根目录下的go.mod
文件来定义。根路径下的module
是项目依赖包的集合,但会排除子目录的go.mod
文件。
下面是go mod
文件模版:
module example.com/m
require (
golang.org/x/text v0.3.0
gopkg.in/yaml.v2 v2.1.0
)
要开始使用go mod
,仅需要在项目下执行go mod init
命令创建go.mod
文件即可。
go mod init example.com/m
Modules and vendoring
当使用module
时,Go
命令会完全忽略vendor
目录。为了跟之前Go
的依赖管理相兼容,我们可以使用go mod vendor
创建vendor
目录来存储编译代码的依赖包。如果在编译的时候要使用vendor
中的依赖包,需要使用go build -mod=vendor
命令。
go mod vendor
go build -mod=vendor
Go Get
首先,go get
解析需要新增哪些依赖。可以通过在包名后添加@version
或者@branch
等方式来取代命令的默认更新行为。如果后缀指定为@none
,则表明该依赖应该被移除。
其次,go get
会下载、编译、安装指定的包。包的安装模式也是被允许的,比如使用go get golang.org/x/perf/cmd/..
来更新cmd
下的所有子包。
go get -u <repo url>
go mod vendor