当前位置: 首页 > article >正文

Go-知识依赖Vendor

Go-知识依赖Vendor

  • 1. 介绍
  • 2. vendor 目录位置
  • 3. 搜索顺序
  • 4. vendor 的不足

1. 介绍

自 Go 1.6 起,vendor 机制正式启用,它允许把项目的依赖放到一个位于本项目的 vendor 目录中,这个 vendor 目录
可以简单理解成私有的 GOPATH 目录。 项目编译时,编译器会优先从 vendor 中寻找依赖包,如果 vendor 中找不到,
则再到 GOPATH 中寻找。

2. vendor 目录位置

一个项目可以有多个 vendor 目录,分别位于不同的目录级别,建议每个项目只在根目录下放置一个 vendor 目录。
假如有一个 github.com/test/testcase 项目,项目目录结构如下:

GOPATH/src/github.com/test/testcase/testpackage/main/main.go

其中 main.go 中依赖如下几个包:

import (
    "golang.org/x/crypto/ssh"
    "github.com/pkg/sftp"
)

在没有使用 vendor 目录时,若想编译这个项目,则 GOPATH 目录经过应该如下:

GOPATH/src/github.com/test/testcase/
GOPATH/src/github.com/pkg/sftp
GOPATH/src/golang.org/x/crypto/ssh

即所有依赖的包都位于 GOPATH/src 下。
为了把所使用到的 golang.org/x/crypto/sshgithub.com/pkg/sftp 版本固化下来,可以使用 vendor 机制。
在项目 github.com/test/testcase/ 根目录下创建一个 vendor 目录,并把 golang.org/x/crypto/sshgithub.com/pkg/sftp
存放到此目录中,让其成为项目的一部分:

GOPATH/src/github.com/test/testcase/testpackage/main/main.go
GOPATH/src/github.com/test/testcase/vendor/github.com/pkg/sftp/
GOPATH/src/github.com/test/testcase/vendor/golang.org/x/crypto/ssh/

使用 vendor 的好处是在项目 github.com/test/testcase 发布时可以把其所依赖的软件一并发布,编译时不会受到 GOPATH 目录的影响,即便 GOPATH 下也有一个
同名但不同版本的依赖包。

3. 搜索顺序

编译器会从源码文件所在的目录开始逐级向上搜索,在上面的例子中,在编译 main.go 时,编译器搜索依赖包的顺序为:

  1. GOPATH/src/github.com/test/testcase/testpackage/main/ 下寻找 vendor 目录,没有找到,继续从上层查找。
  2. GOPATH/src/github.com/test/testcase/testpackage/ 下寻找vendor 目录,没有找到,继续从上层查找。
  3. GOPATH/src/github.com/test/testcase/ 下寻找 vendor 目录,从 vendor 目录中查找到依赖包,结束查找。

如果 GOPATH/src/github.com/test/testcase/ 下的 vendor 目录中没有依赖包,则返回 GOPATH 目录继续查找。这就是 GOPATH 机制了。
实际上 vendor 目录可以存在于项目的任意目录下。但是不推荐,如果 vendor 目录过于分散,则可能同一个依赖包在项目的多个 vendor 中出现
多次,这样依赖包会多次编译进二进制文件,从而造成二进制文件的体积急剧增大,也很可能出现一个项目中使用同一个依赖包的多个版本的情况。

4. vendor 的不足

vendor 很好地解决了多项目间的隔离问题,但是也有一些不足之处:

  • 项目依赖关系不清晰,无法清楚地看出 vendor 目录中依赖包的版本。
  • 依赖包升级时很不方便审核。

更严重的是二进制文件的体积急剧增大的问题,比如项目依赖开源包A和B,但是A中也有一个vendor目录,其中也放了B,那么项目中将出现两个开源包B。
如果两个开源包B的版本不一致或者不兼容,那么后果非常可怕。

vendor 能够解决大部分项目中的问题,但是也存在很多的不足之处。


http://www.kler.cn/news/360883.html

相关文章:

  • 025 elasticsearch索引管理-Java原生客户端
  • 【MySQL】提高篇—索引与性能优化:索引的概念与类型(单列索引、复合索引、全文索引)
  • 手机功耗技术领域
  • Hadoop 踩坑汇总
  • Clip 模型实现文搜图
  • web网页QQ登录
  • 【JavaEE初阶】网络编程TCP协议实现回显服务器以及如何处理多个客户端的响应
  • rpm 命令
  • Java项目-基于springboot框架的逍遥大药房管理系统项目实战(附源码+文档)
  • 上海市计算机学会竞赛平台2024年10月月赛丙组游戏闯关
  • Qt-Git
  • 总结一下 Promise,怎么使用,如何手写 promise
  • 文件处理新纪元:微信小程序的‘快递员’与‘整理师’
  • |动漫爬取|001_djangodjango基于Spark的国漫推荐系统的设计与实现2024_tpd6q1o4
  • 【java】抽象类和接口(了解,进阶,到全部掌握)
  • 羟基-聚乙二醇-羧基 HO-PEG-COOH的应用MW:3400 CAS:39828-93-8 纳米技术
  • 好用的文件加密软件有哪些?2024年国内外10款文件加密软件推荐
  • elk部署安装
  • redis过期提醒
  • Scrapy | 通过模拟登录功能认识cookies参数及start_requests函数实现发送POST请求