Go 模块、私有存储库和 GOPATH 的角色
在从 dep 依赖管理器到 Go 模块的过渡中,了解其含义代码结构和依赖关系的模块化至关重要。本文深入探讨了使用存储在私有存储库中的内部依赖项的 Go 模块的细微差别。
无点路径和标准存储库
Go 模块的设计目的是仅为标准库保留无点路径(例如 mycompany/mylib)。这源于大多数使用模块的项目将使用 go get 从公共存储库导入依赖项的期望。然而,内部依赖关系呈现出不同的情况。
模块和 GOPATH
Go 模块旨在提供标准化的依赖关系管理系统,以简化版本控制并减少手动干预的需要。当项目使用模块时,意味着所有依赖项也必须遵循模块系统。 GOPATH 虽然仍然充当下载模块的缓存,但失去了以前作为主要依赖项解析器的作用。
私有存储库和离线开发
使用私有存储库内部依赖关系引入了身份验证的需要。虽然 Go 模块中的私有存储库处理仍在开发中,但可以采用使用环境变量(例如 GITHUB_TOKEN)和配置 Git URL 等解决方法。
此外,可以通过 $ 解决对离线开发的担忧GOPROXY 环境变量,如 Russ Cox 在 vgo 上的博客文章中所述。通过适当设置 $GOPROXY,可以在本地缓存依赖项,从而在使用私有存储库时启用离线开发。
依赖项解析
启用模块后,Go 假定所有依赖项都必须使用模块系统来解决。这意味着开发人员不能再依赖 GOPATH 来解决示例中的 mycompany/mylib 等依赖项。
要解决此问题,需要将内部依赖项(例如 mylib)移出GOPATH 或在依赖项内的 go.mod 文件中显式将其声明为依赖项
结论
Go 模块提供了一种结构化的方式来管理依赖关系,特别是对于依赖公共存储库的项目。但是,在私有存储库中使用具有内部依赖项的 Go 模块需要额外考虑身份验证、离线开发和依赖项解析。通过利用 GITHUB_TOKEN 和 $GOPROXY 等解决方法,开发人员可以应对这些挑战并采用一致的方法进行依赖关系管理。
以上是Go 模块如何处理私有存储库以及 GOPATH 的过时角色?的详细内容。更多信息请关注PHP中文网其他相关文章!