dep是一个golang依赖管理工具,需要在Go 1.7及更高的版本中使用。
1. 安装
安装dep工具的方式有很多种,如果是mac电脑的话,只需要如下命令:
brew install dep
对于Linux和类Unix系统而言,我们还可以使用如下方式安装dep:
curl https://raw.githubusercontent.com/golang/dep/master/install.sh | sh
或者直接使用源码安装。
而对于windows电脑,可以使用命令行:
go get -u github.com/golang/dep/cmd/dep
会自动下载到go_path/bin/目录下,你需要将go_path/bin 加入到环境变量中。
如果这种方式下载不下来,你也可以手动下载:点击这里,挑选适合你的版本,然后修改文件名为dep.exe放入go_path/bin/目录下。
2. 使用
安装完毕再命令行下敲入dep命令:
$ dep
Dep is a tool for managing dependencies for Go projects
Usage: "dep [command]"
Commands:
init Set up a new Go project, or migrate an existing one
status Report the status of the project's dependencies
ensure Ensure a dependency is safely vendored in the project
prune Pruning is now performed automatically by dep ensure.
version Show the dep version information
Examples:
dep init set up a new project
dep ensure install the project's dependencies
dep ensure -update update the locked versions of all dependencies
dep ensure -add github.com/pkg/errors add a dependency to the project
Use "dep help [command]" for more information about a command.
如上:
init命令用来初始化项目;
status命令用来查看当前项目的依赖状态;
ensure命令用来同步依赖包
3. 初始化
切换到你的工程目录下:
cd $GOPATH/src/goProject
假设项目现在是空的,什么也没有,进行初始化:
dep init -v
注意:因为墙的原因,,,不一定我们能成功的拉下来依赖,使用dep init 尽量带上-v:
-v enable verbose logging (default: false)
如果半分钟没响应就ctrl+c中断,就可以看到fail的原因,dep遇到一些错误不会立马报错(特别是网络原因) 。
执行成功之后会生成两个文件 Gopkg.lock、Gopkg.toml和一个文件夹vendor
Gopkg.toml文件记录着current project依赖项project的约束。
Gopkg.toml参数解释:
[[constraint]]: 这个约束主要体现在到底要采用目标project的某个tag的版本(version),还是某个branch,或者是某个revision,这三个对于一个constraint只能选一个。
[[override]]:有时项目依赖比较复杂,经常会遇到依赖冲突导致 dep ensure 命令无法执行成功,这个时候使用 override 消除单个依赖关系上多个不可调和的constraint声明之间的分歧
[[required]]:列出了必须包含在Gopkg.lock中的一组包
[[ignored]]:列出dep静态分析源代码时忽略的一组包
[[prune]]:prune为依赖关系定义全局和每个项目的prune选项。 这些选项决定写入vendor/时丢弃哪些文件
- unused-packages:修剪掉来自于目录中,但是没有出现在包导入图中的文件
- non-go:修剪掉非.go文件
- go-tests:修剪掉Go的测试文件
Gopkg.lock文件是工具生成的,你不用手工编辑
vendor文件里面存放current project的远程依赖的源代码
当需要指定目标project使用哪一个version时,可以在Gopkg.toml中添加。如,需要指定alice版本为0.8.4,在Gopkg.toml中添加:
[[constraint]]
name = "github.com/golang/dep"
version = "=0.8.4"
然后执行
dep ensure -update "github.com/golang/dep
在指定version的时候,如果指定semantic version,可选的符号有
- =: 只选择对应version
- >或<: 大于(或小于)对应版本号
- >=或<=: 大于等于(或小于等于)对应版本号
- ~: ~1.2.3表示 >=1.2.3,<1.3.0
- ^: ^1.2.3表示 >1.2.3,<2.0.0
不指定符号的话,默认为^符号。
有了包管理工具之后,好处还是挺多:
- 帮你锁住依赖版本,防止第三方包升级导致代码不兼容;
- 将项目的依赖都放在vendor下,就不用依赖gopath下的公共包了;
4. 添加依赖
依赖管理帮助
`dep help ensure`
添加一条依赖
`dep ensure -add github.com``/bitly/go-simplejson`
一次性添加多条依赖
`dep ensure -add github.com``/pkg/errors` `github.com``/bitly/go-simplejson`
添加依赖指定依赖版本
`dep ensure -add github.com``/bitly/go-simplejson``@=0.4.3`
添加后记住执行dep ensure确保同步
`dep ensure -``v`
如果执行dep ensure出错,看下Gopkg.toml文件中是否同时配置了version,branch和revision。