管理通过非标准端口访问的自定义 Go 模块

Wil*_*lin 5 go vendoring go-modules

背景

在我的公司,我们使用 Bit Bucket 来托管 git 存储库。流向服务器的所有流量都流经自定义的非标准端口。从我们的存储库克隆看起来像这样git clone ssh://git@stash.company.com:9999/repo/path/name.git

问题

我想创建托管在该服务器上并由 管理的 Go 模块go mod,但是,流量必须流经端口这一事实9999使得这非常困难。这是因为go mod在标准端口上运行,并且似乎没有提供为不同模块自定义端口的方法。

我的问题

是否可以使用go mod非标准端口来管理托管在私有 git 服务器上的 Go 模块?

尝试过的解决方案

售货

这似乎是最接近提供解决方案的。首先我是go mod vendor想要使用这些 Go 模块的 Go 应用程序,然后是目录git submodule中的 Go 模块vendor/。在需要更新或添加模块的情况下,这可以完美地工作。go mod tidy将一直无法下载或更新其他 Go 模块,因为它无法访问自定义 Go 模块的“git URL”。即使-e设置了标志。

编辑.gitconfig

编辑以.gitconfig将不带端口的 URL 替换为带端口的 URL 是一种可行的解决方案,但这是一种非常肮脏的黑客行为。首先,必须对任何新模块以及每个开发人员进行这些编辑。其次,在处理这些存储库时,这可能会中断其他 git 进程。

Ala*_*ska 4

go工具在底层使用 git,因此您需要在您的环境中配置 git 以使用备用 url。就像是

git config --global url."ssh://git@stash.company.com:9999/".insteadOf "https://stash.company.com"
Run Code Online (Sandbox Code Playgroud)

虽然我记得 bitbucket/stash 有时会因为我不记得的原因提供额外的后缀,所以你可能需要这样做:

git config --global url."ssh://git@stash.company.com:9999/".insteadOf "https://stash.company.com/scm/"
Run Code Online (Sandbox Code Playgroud)

额外编辑

用户 bcmills 下面提到,您还可以通过 HTTPS 提供 go-import 元数据,并使用您喜欢的任何虚荣 URL,前提是您控制域解析。这可以通过不同程度的复杂程度来完成,从简单的 nginx 规则静态内容生成器专用虚荣服务,甚至使用Athens运行您自己的模块代理

但是,这仍然不能完全解决构建环境配置的问题,因为您希望用户根据您的配置进行设置或两者兼而有之GOPRIVATEGOPROXY

此外,如果您选择的域名可能是全局可解析的,您可能需要考虑注册它,以防止它被潜在的恶意第三方注册。

  • 基于每个开发人员构建环境配置是很常见的事情,所以我不确定您还希望如何管理它。这与需要每个开发人员使用私有的内部 VCS 建立身份没有太大区别。这已经是一种最佳实践。我不确定你所说的“随着模块数量的增加而添加的新模块”是什么意思。对 gitconfig 的全局更改应该处理来自内部存储库的任何模块。 (2认同)