go mod 简介
golang 中 mod 的简介以及使用
GOMOD
GOROOT & GOPATH
如果没有自行设置的话,GOROOT 会取 /usr/lib/go 作为默认值,而 GOPATH 则会取 $HOME/go。
依赖管理目标:
API 稳定性和可重现构建
go_version < 1.12
go get位置:$GOPATH/src
go_version >= 1.13
go mod
GO111MODULE
$GOPATH/pkg/mod
go get : 不再循环拉取submodule子模块
go mod 使用 最小版本选择(Minimal Version Selection)算法:为每个模块指定的依赖都是可用于构建的最低版本,最后实际选择的版本是所有出现过的最低版本中的最大值。
go.mod 包含四部分:
module:
module /path/to/your/mod/v2 用来声明当前 module,如果当前版本大于 v1 的话,还需要在尾部显式的声明 /vN。
require:
require /your/mod tag/branch/commit/latest 可以使用 latest 来表示引用最新的 commit。如果对应的引用刚好是一个 Tag 的话,这个字符串会被重写为对应的 tag;如果不是的话,这个字符串会被规范化为形如 v2.0.0-20180128182452-d3ae77c26ac8 这样的字符串。
replace:只能作用于当前模块的构建。
replace original_name => real_name tag/branch/commit replace original_name => local_path replace test.dev/common => git.example.com/bravo/common.git v0.0.0-20190520075948-958a278528f8 replace test.dev/common => ../../another-porject/common-go
exclude:只能作用于当前模块的构建
vendor
使用 go mod vendor 只是单纯地把 go.sum 中的所有依赖下载到 vendor 目录里,如果你用它迁移 godep 你会发现 vendor 目录里的包会和 godep 指定的产生相当大的差异,所以请务必不要这样做。
使用 go build -mod=vendor 来构建项目,因为在 go modules 模式下 go build 是屏蔽 vendor 机制的,所以需要特定参数重新开启 vendor 机制。
常用指令
go mod graph | grep XXX 来看看谁在依赖这个XXX模块: go list -m all 列出当前模块依赖的所有模块 go list -u -m all 列出当前模块依赖中可升级的模块 go get -u 升级所有依赖至最新版本 go get -u=patch 升级所有依赖至最新的修订版本 go mod tidy 清理未使用/生效的依赖
reference
Last updated
Was this helpful?