go get: Git 设置被忽略
go get: Git settings are ignored
我尝试从 mac.
的私人 git 实验室服务器获取存储库
我将 git 配置 (~/.gitconfig) 设置为使用 ssh 而不是 https:
[url "git@gitlab.mysite.com:"]
insteadOf = https://gitlab.mysite.com/
当我使用 https url 克隆项目时,我得到了正确的替换
$ git clone https://gitlab.mysite.com/group/project
$ cd project
$ git remote -v
origin git@gitlab.mysite.com:group/project (fetch)
origin git@gitlab.mysite.com:group/project (push)
然而,当我使用 go get 时,它尝试使用 https url,但失败了
$ go get gitlab.mysite.com/group/project
package gitlab.mysite.com/group/project: unrecognized import path "gitlab.mysite.com/group/project" (https fetch: Get https://gitlab.mysite.com/group/project?go-get=1: x509: certificate signed by unknown authority)
为什么 go get 没有使用我的 git 配置?我该如何解决?
我知道这个问题类似于这个问题: 和许多其他有关私人回购的问题
我的问题不一样
该错误发生在 git clone
调用之前。当您调用 go get
时,它会向 URL 发出 HTTPS 调用以检查 headers 并查看它是否提供 go get
重定向。这就是失败的原因。
它失败了,因为服务器提供的证书不是由您在本地系统上指定为受信任的证书颁发机构签署的。这可能是因为您的内部 gitlab 正在使用未签名的证书,因为用于签署它的 CA 尚未添加到您的本地系统,或者因为您的工作场所正在使用 man-in-the-middle 样式代理而您没有该代理的 CA 已添加。您可以尝试修复证书问题,或者只是 运行:
go get -insecure gitlab.mysite.com/group/project
The -insecure flag permits fetching from repositories and resolving
custom domains using insecure schemes such as HTTP. Use with caution.
值得注意的是,这会绕过用于签署服务器证书的 CA 的验证。
我尝试从 mac.
的私人 git 实验室服务器获取存储库我将 git 配置 (~/.gitconfig) 设置为使用 ssh 而不是 https:
[url "git@gitlab.mysite.com:"]
insteadOf = https://gitlab.mysite.com/
当我使用 https url 克隆项目时,我得到了正确的替换
$ git clone https://gitlab.mysite.com/group/project
$ cd project
$ git remote -v
origin git@gitlab.mysite.com:group/project (fetch)
origin git@gitlab.mysite.com:group/project (push)
然而,当我使用 go get 时,它尝试使用 https url,但失败了
$ go get gitlab.mysite.com/group/project
package gitlab.mysite.com/group/project: unrecognized import path "gitlab.mysite.com/group/project" (https fetch: Get https://gitlab.mysite.com/group/project?go-get=1: x509: certificate signed by unknown authority)
为什么 go get 没有使用我的 git 配置?我该如何解决?
我知道这个问题类似于这个问题:
我的问题不一样
该错误发生在 git clone
调用之前。当您调用 go get
时,它会向 URL 发出 HTTPS 调用以检查 headers 并查看它是否提供 go get
重定向。这就是失败的原因。
它失败了,因为服务器提供的证书不是由您在本地系统上指定为受信任的证书颁发机构签署的。这可能是因为您的内部 gitlab 正在使用未签名的证书,因为用于签署它的 CA 尚未添加到您的本地系统,或者因为您的工作场所正在使用 man-in-the-middle 样式代理而您没有该代理的 CA 已添加。您可以尝试修复证书问题,或者只是 运行:
go get -insecure gitlab.mysite.com/group/project
The -insecure flag permits fetching from repositories and resolving custom domains using insecure schemes such as HTTP. Use with caution.
值得注意的是,这会绕过用于签署服务器证书的 CA 的验证。