为什么即使配置了SSH,“go get”还是使用HTTPS?

9

我已经正确配置了ssh,可以通过ssh处理我们的私有repo中的git内容。但是当我使用go getgo test(针对go modules)进行测试时,命令行界面却没有使用ssh,而是使用https。

.gitconfig

[url "ssh://git@bitbucket.company.com:7999"]
    insteadOf = https://bitbucket.company.com/scm

~/.ssh/config

Host bitbucket.company.com
 User git
 Port 7999
 IdentityFile ~/.ssh/id_rsa

测试 SSH 是否正常工作

$ git ls-remote ssh://git@bitbucket.company.com:7999/project/repo.git
ab86e12ab20775a308b7d0b003ba562263fbfa23        HEAD
ab86e12ab20775a308b7d0b003ba562263fbfa23        refs/heads/master
ab86e12ab20775a308b7d0b003ba562263fbfa23        refs/tags/v0.0.1

测试go get

$ go get -v bitbucket.company.com/project/repo
go get bitbucket.company.com/project/repo: unrecognized import path "bitbucket.company.com/project/repo": https fetch: Get "https://bitbucket.company.com/project/repo?go-get=1": dial tcp 10.68.204.3:443: connectex: A connection attempt failed because the connected party did not properly respond after a period of time, or established connection failed because connected host has failed to respond.

go version

go version go1.14.1 windows/amd64

go env

set GO111MODULE=on
set GOARCH=amd64
set GOBIN=
set GOCACHE=C:\Users\sailhenz\AppData\Local\go-build
set GOENV=C:\Users\sailhenz\AppData\Roaming\go\env
set GOEXE=.exe
set GOFLAGS=
set GOHOSTARCH=amd64
set GOHOSTOS=windows
set GOINSECURE=
set GONOPROXY=none
set GONOSUMDB=*.company.com
set GOOS=windows
set GOPATH=C:\Users\sailhenz\Documents\Development\Go
set GOPRIVATE=*.company.com
set GOPROXY=https://goproxy.io,direct
set GOROOT=C:\Users\sailhenz\Documents\Software\go
set GOSUMDB=off
set GOTMPDIR=
set GOTOOLDIR=C:\Users\sailhenz\Documents\Software\go\pkg\tool\windows_amd64
set GCCGO=gccgo
set AR=ar
set CC=gcc
set CXX=g++
set CGO_ENABLED=1
set GOMOD=NUL
set CGO_CFLAGS=-g -O2
set CGO_CPPFLAGS=
set CGO_CXXFLAGS=-g -O2
set CGO_FFLAGS=-g -O2
set CGO_LDFLAGS=-g -O2
set PKG_CONFIG=pkg-config
set GOGCCFLAGS=-m64 -mthreads -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -fdebug-prefix-map=C:\Users\sail~1\AppData\Local\Temp\go-build227330694=/tmp/go-build -gno-record-gcc-switches

我是否错过了任何设置或配置?提前感谢。


bitbucket.company.com/project/repohttps://bitbucket.company.com/scm不匹配。 - ElpieKay
即使匹配了模式,仍然没有成功。 - sailhenz
嘿,看看这个帖子:https://github.com/golang/go/issues/27344 - shmsr
我设法追踪到了问题,似乎在导入路径中添加.git可以解决它。这里是线程链接https://github.com/golang/go/issues/27254,供有相同问题的人参考。 - sailhenz
@sailhenz 很好的发现。我在下面的答案中包括了这个问题,并详细说明了由于导入路径中缺少 .git 导致的问题。 - VonC
1个回答

0

尝试:

[url "bitbucket.company.com:"]
    insteadOf = https://bitbucket.company.com/

这将把任何https://bitbucket.company.com/转换为bitbucket.company.com:,然后会:

  • 被解释为SSH URL
  • 通过~/.ssh/config进行解码,变成ssh://git@bitbucket.company.com:7999/...

关键是只使用bitbucket.company.com,它是您的~/.ssh/config文件中的主机条目,这意味着它将引用正确的私钥文件。


Subham Sarkar 在评论中报告问题,该问题与golang/go的27344号问题有关。

上述解决方案似乎无法在Go 1.13中使用,并且已在Go 1.14的“待办事项”中。

检查测试是否可以使用相同的go get在Go 1.11中运行。


OP sailhenz评论中提到了问题27254

cmd/go:自定义导入路径私有存储库需要特殊配置

在导入路径中添加.git即可解决

该票据补充道:

之所以 .git 解决方案有效,是因为它帮助指导 go 工具 获取有关自定义导入路径 private.repo.net/user/package.git/... 的版本控制系统(即 (https|ssh)://private.repo.net/user/package.git)的信息。

如果没有这个(例如使用导入路径 private.repo.net/user/package/a),则 go 工具 首先查询 https://private.repo.net/user/package/a?go-get=1 来确定(根据 https://tip.golang.org/cmd/go/#hdr-Remote_import_paths)该自定义导入路径的版本控制系统位于何处。

go get -x private.repo.net/user/package 是调试此问题的好方法。


我仍然遇到同样的问题。go get 似乎在尝试通过 https 连接。``` dial tcp 10.68.204.3:443: connectex: 由于连接方在一段时间后没有正确答复或已建立的连接失败,因此连接尝试失败,或者连接的主机没有反应。 - sailhenz
@sailhenz 你使用的 Go 版本是什么(请参见我的编辑答案)? - VonC
我正在使用 go version go1.14.1 windows/amd64。我也尝试了线程中提供的解决方案,并尝试降级到1.12.9,但仍然没有运气。它仍然在尝试使用https连接,所以我无法下载任何私有存储库。我将尝试使用1.11并查看问题是否仍然存在。 - sailhenz
我已经降级到 go version go1.11.13 windows/amd64,但 go get 仍然使用 https。正在获取 https://bitbucket.company.com/project/repo?go-get=1 https 获取:获取 https://bitbucket.company.com/project/repo?go-get=1: 拨号 tcp 10.68.204.3:443: connectex: 连接方在一段时间后没有正确地响应,或者已经建立的连接失败,因为连接的主机没有响应。)。我将把我的 go env 放在原问题中。 - sailhenz
@sailhenz 好的,另一个问题是什么?你能把你的路径也加上吗? - VonC

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接