这世上太多的人,宁愿吃生活苦,也不愿吃自律的苦。大概是因为生活的苦,躺着就来了,而自律的苦,得自己去找。但只有吃得下自律的苦,才有成功的自由,没有一种成功是走得了捷径的,通向真正成功的唯一道路只有自律。越成功,越自律。越自律,越成功。
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
当使用module 时,Go 命令会完全忽略vendor 目录。为了跟之前Go 的依赖管理相兼容,我们可以使用go mod vendor 创建vendor 目录来存储编译代码的依赖包。如果在编译的时候要使用vendor 中的依赖包,需要使用go build -mod=vendor 命令。
go mod vendor
go build -mod=vendor
The -u flag instructs get to use the network to update the named packages and their dependencies. By default, get uses the network to check out missing packages but does not use it to look for updates to existing packages.
首先,go get 解析需要新增哪些依赖。可以通过在包名后添加@version 或者@branch 等方式来取代命令的默认更新行为。如果后缀指定为@none ,则表明该依赖应该被移除。
其次,go get 会下载、编译、安装指定的包。包的安装模式也是被允许的,比如使用go get golang.org/x/perf/cmd/.. 来更新cmd 下的所有子包。
go get -u <repo url>
go mod vendor
熟悉govendor 的肯能会有一种熟悉的感觉,这不就是govendor add +e 吗?
留步
看过的话,顺带关注一下公众号,欢迎投稿。关注了记得要留言!!
|
请发表评论