Govendor使用

Govendor使用

govendor 简介

govendor是一个基于 vendor 机制实现的 Go 包依赖管理命令行工具。与原生 vendor 无侵入性融合,也支持从其他依赖管理工具迁移,可以很方便的实现同一个包在不同项目中不同版本、以及无相互侵入的开发和管理。

安装govendor

go get -u -v github.com/kardianos/govendor

注:如果出现Git连接超时的异常,因为是公司内网吧,需要设置代理

git config --global http.https://github.com.proxy http://web-proxy.oa.com:8080

安装完成之后在GOPATH下 的src下会有src\github.com\kardianos\govendor目录

使用govendor

#进入到项目目录
cd /home/gopath/src/mytool
 
#初始化vendor目录
govendor init

初始化之后项目根目录下即会自动生成 vendor 目录和 vendor.json 文件。此时 vendor.json 文件内容为:

{
	"comment": "",
	"ignore": "test",
	"package": [],
	"rootPath": "govendor-example"
}

下面命令可以将项目中已被引用且在 $GOPATH 下的所有包复制到 vendor 目录,vendor.json也会加入引入的package描述。注:如果本地GOPATH没有依赖包,需要先go get相应的依赖包 。若获取gin时遇到下载不下来文件,需要手动去github上下载然后放到指定目录->看最后

govendor add +external

或者仅从 $GOPATH 中复制指定包

govendor add gopkg.in/yaml.v2

列出代码中所有被引用到的包及其状态

govendor list
D:\Go_WorkSpace\src\myproject>govendor list
 v  github.com/gin-contrib/sse
 v  github.com/gin-gonic/gin
 v  github.com/gin-gonic/gin/binding
 v  github.com/gin-gonic/gin/internal/json
 v  github.com/gin-gonic/gin/render
 v  github.com/golang/protobuf/proto
 v  github.com/mattn/go-isatty
 v  github.com/ugorji/go/codec
 v  gopkg.in/go-playground/validator.v8
 v  gopkg.in/yaml.v2
pl  myproject/main
  m github.com/json-iterator/go
  m golang.org/x/sys/unix

如果忽略了 vendor/*/ 文件,可用 govendor sync 恢复依赖包

govendor sync

从远程仓库添加或更新某个包(不会在 $GOPATH 也存一份)

govendor fetch golang.org/x/net/context

需要安装指定版本的包

govendor fetch golang.org/x/net/context@a4bbce9fcae005b22ae5443f6af064d80a6f5a55
govendor fetch golang.org/x/net/context@v1   
govendor fetch golang.org/x/net/context@=v1  

安装gin 的时候遇到这个问题
在这里插入图片描述

搜索缺失的包,找到github地址,去Git clone

D:\Go_WorkSpace\src\github.com\gin-gonic\gin\vendor\gopkg.in\go-playground\validator.v8

D:\Go_WorkSpace\src\github.com\gin-gonic\gin\vendor\gopkg.in\yaml.v2

把下载下来的目录里的内容放入上面两个目录下

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值