Go依赖管理

起源


最早的时候,Go所依赖的所有的第三方库都放在GOPATH这个目录下面。这就导致了同一个库只能保存一个版本的代码。如果不同的项目依赖于同一个第三方的库的不同版本,应该怎么解决?
答案是把第三方库复制到项目中去。同时需要重写import的路径,也就是把原本依赖的GOPATH下面的路径改写成项目的路径。如果第三方库本身还依赖于别的项目,情况就变得更加复杂。更加蛋疼的是,同一套的代码,在不同的机器上,由于机器上第三方库版本的不同,会产生不同的行为。这在多人合作的项目中是没办法接受的。

转机


到了Go1.5版本,终于出现了转机。官方支持了vendor机制。
所谓支持vendor,其实就是在每个项目中增加了一个特殊的名叫vendor的目录。
Go在引入的时候,会按照以下顺序去寻找第三方库。

  1. 当前包下的vendor目录。
  2. 向上级目录查找,直到找到src下的vendor目录。
  3. 在GOPATH下面查找依赖包。
  4. 在GOROOT目录下查找
    这种机制给了每个项目多一点的自主权,他们再也不用看整个Go环境的脸色了,终于拥有了自己选择自己想要的第三方库版本的自由。

管理


出现了vendor机制后,就涌现出了许多包管理工具。这些工具的基本原理大致相同。

  1. 解析项目中依赖的第三方库;
  2. 指定第三方库所用版本;
  3. 拉取第三方库代码到vendor目录下。

问题


目前这种解决方式存在一个问题,就是会产生大量第三方库的副本。当然,现在机器配置基本上不在乎这些硬盘消耗,所以这个问题大概也不是什么大问题。因此,官方似乎也没打算花力气解决这个问题。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 长期以来,golang 对外部依赖都没有很好的管理方式,只能从 $GOPATH 下查找依赖。这就造成不同用户在安装...
    糖果果老师阅读 5,192评论 0 3
  • govendor是类似于npm的一个包管理工具该工具将项目依赖的外部包拷贝到项目下的 vendor 目录下,并通过...
    blossom_绽放阅读 13,150评论 0 5
  • 引言 Go 语言这两年在语言排行榜上的上升势头非常猛,Go 语言虽然是静态编译型语言,但是它却拥有脚本化的语法,支...
    一缕殇流化隐半边冰霜阅读 33,656评论 11 90
  • 思考改变行为 行为改变习惯 习惯改变个性 个性改变人生 世界已经变了,更换思路,旧的模式需要推敲了再套用 动作快一...
    复苏森林阅读 818评论 0 1
  • 二十九 阳光 三十 一片嫩绿的叶 在杯中 演绎春天 三十一 去往南方的候鸟 迷失 晨雾中 2016/9/26 晨...
    萧路遥阅读 1,166评论 0 0

友情链接更多精彩内容