Gitlab - git clone 在 macOS 中使用 ssh 和 https 都失败了



我的同事授予我作为主数据库访问他的存储库的权限,然后我使用 SSH 和 HTTPS 克隆它,但它总是失败:

GitLab: The project you were looking for could not be found.
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.

我已经检查了.pub文件中生成的公钥,并且已经插入到我的 Gitlab 帐户中。 而且我也尝试克隆一个存储库(来自其他所有者(,它可以工作! 令人困惑。

我错过了什么吗?

我遇到了同样的问题,我发现了多个问题。我不是这方面的专家,但以下是我为解决而采取的步骤的摘要。 希望它会有所帮助:

解决 HTTPS 克隆问题:

  1. 克隆因上述错误而失败,并且没有在命令行上提示我输入用户名和密码。 使用详细标志运行克隆

    git clone --progress --verbose https://[my_gitlab_server]/[repo]/[project].git

    显示 git 正在从 OSX 工具链中提取凭据,这显然是不正确的。 我在这里使用说明禁用了它。

    sudo git config --system --unset credential.helper

  2. 我现在收到用户名和密码提示,但得到:

    remote:HTTP 基本:拒绝访问 远程:必须对 HTTP 上的 Git 使用具有"api"范围的个人访问令牌。 remote:您可以在 https://[my_gitlab_server]/profile/personal_access_tokens 致命:"https://[my_gitlab_server]/[存储库]/[项目].git/"的身份验证失败

    因此,我按照此处的说明创建了一个个人访问令牌。

  3. 我不确定如何处理令牌。 事实证明,您可以按照此处所述将其包含在URL中(对我来说看起来像git clone https://oauth2:[token]@[my_gitlab_server]/[project].git(,或者您可以将令牌粘贴到命令行提示符处输入"密码"。

我现在可以通过HTTPS克隆。

解决 SSH 克隆问题:

SSH 克隆给出与 HTTPS 克隆相同的错误。一些关于 bash 代理的背景在这里很有帮助。

  1. 我在用户目录中找到了我的~/.ssh/config文件,并验证了存储库在那里有一个条目。

    Host [my_gitlab_server]/[repo] IdentityFile ~/.ssh/id_rsa2

  2. 我在 ssh 目录中有多个 id-rsa 文件,所以我打开了id_rsa2.pub(与配置文件中的存储库关联的文件(,并通过导航到"配置文件设置"中的"SSH 密钥"选项卡,将其与我在存储库中找到的密钥进行比较。 钥匙是一样的。

    (如果需要有关创建和查看密钥的帮助,请参阅此处的文档。

我的密钥已就位,但我的 SSH 克隆仍然无法正常工作。

  1. 我认为配置文件可能有问题,或者我的密钥不再有效,所以我通过使用此处的说明手动将密钥添加到当前终端会话来绕过配置文件。

    eval $(ssh-agent -s) ssh-add ~/.ssh/id_rsa2

    这有效,所以我知道我的密钥是有效的。

    (顺便说一下,要查看加载到代理中的密钥运行ssh-add -L并查看其指纹运行ssh-add -l.(

现在的问题是我需要使用~/.ssh/config文件,这样我就不必每次打开新的终端窗口时都运行evalssh-add

  1. 要进行故障排除,我运行了成功连接到我的 gitlab 服务器的ssh -Tvv git@[my_gitlab_server],但使用了我不认识的密钥。 在输出中,我注意到没有搜索文件id-rsa2
  2. 使用来自 ssh.com 的有关密钥和ssh_config文件的信息,我发现/etc/private/ssh/ssh_config文件指定了使用哪些密钥。 默认值为:

    IdentityFile ~/.ssh/id_rsa IdentityFile ~/.ssh/id_dsa IdentityFile ~/.ssh/id_ecdsa IdentityFile ~/.ssh/id_ed25519

    我通过运行sudo nano /private/etc/ssh/ssh_config并添加以下行来添加我的id_rsa2键:

    IdentityFile ~/.ssh/id_rsa2

这就像一个冠军。

总的来说,最好使用具有默认id_rsa名称的单个 ssh 密钥,以避免此类问题。

好的,你能检查一下你的 git globals 是否正确吗,尊重你的 GitLab 帐户。

$ git config --global user.name "Your name"
$ git config --global user.email your@mail.com

当我的数据出错时,我在克隆时遇到了一些问题。

最新更新