首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【已解决】GitHub SSH 连接失败解决方案:Permission Denied (publickey) 错误修复指南

【已解决】GitHub SSH 连接失败解决方案:Permission Denied (publickey) 错误修复指南

作者头像
未名编程
发布2025-07-22 09:31:59
发布2025-07-22 09:31:59
7270
举报
文章被收录于专栏:PythonPython

在使用 Git 进行版本控制时,有时我们会遇到以下错误提示:

代码语言:javascript
复制
Cloning into 'App'...
ssh: connect to host github.com port 22: Connection timed out
fatal: Could not read from remote repository.

Please make sure you have the correct access rights
and the repository exists.
1. 测试 SSH 连接是否成功

首先,通过 SSH 测试是否能成功连接到 GitHub。可以使用以下命令:

代码语言:javascript
复制
ssh -T git@github.com

如果连接不成功,你可能会看到如下报错:

代码语言:javascript
复制
ssh: connect to host github.com port 22: Connection timed out
fatal: Could not read from remote repository.

如果是这种情况,你可以尝试使用 ping github.com 来检测网络是否通畅。如果你在国内,可能需要使用代理(如全局代理 Tun)来解决网络问题。

ping test
ping test
2. Permission Denied (publickey) 错误解析

如果你遇到 Permission denied (publickey) 错误,通常意味着 GitHub 没有正确识别你的 SSH 密钥。这个问题通常是由于 SSH 密钥没有正确配置或没有被添加到 GitHub 账户导致的。接下来我们来一步步解决。

3. 检查 SSH 密钥是否已生成

查看是否有 SSH 密钥

打开 C:\Users\xxxx\.ssh 目录,检查是否有 id_rsaid_rsa.pub 文件。如果这些文件已经存在,说明你已有 SSH 密钥。否则,你需要生成一个新的 SSH 密钥对。

生成新的 SSH 密钥

如果你没有现成的 SSH 密钥,可以通过以下命令生成新的密钥对:

代码语言:javascript
复制
ssh-keygen -t rsa -b 4096 -C "xxxxxxxxx.com"

这时系统会提示你选择密钥的存储位置,通常按 Enter 选择默认路径(~/.ssh/id_rsa)。你也可以设置密钥密码,或者直接按 Enter 跳过此步骤。

SSH keygen
SSH keygen
4. 将 SSH 公钥添加到 GitHub

生成 SSH 密钥后,你需要将公钥添加到 GitHub 才能正常进行身份验证。

  1. 查看公钥: 打开 id_rsa.pub 文件,复制其中的公钥内容(以 ssh-rsa 开头,以你的电子邮件结尾)。
  2. 将公钥添加到 GitHub: 登录到 GitHub,并按照以下步骤操作:
    • 点击右上角的头像,选择 Settings(设置)。
    • 在左侧导航栏中选择 SSH and GPG keys
    • 点击 New SSH key 按钮。
    • Title 中为你的密钥取个名字,并将刚才复制的公钥粘贴到 Key 栏中。
    • 点击 Add SSH key 保存。
GitHub Add SSH Key
GitHub Add SSH Key
5. 测试 SSH 连接

完成公钥添加后,使用以下命令再次测试 SSH 连接:

代码语言:javascript
复制
ssh -T git@github.com

如果一切顺利,你应该看到如下信息:

代码语言:javascript
复制
Hi username! You've successfully authenticated, but GitHub does not provide shell access.

此时说明 SSH 配置成功,可以进行 Git 操作了。

SSH test
SSH test
6. 确保使用正确的 SSH 密钥

如果你有多个 SSH 密钥,你可能需要显式指定要使用的密钥。可以使用以下命令来指定:

代码语言:javascript
复制
ssh -i ~/.ssh/id_rsa -T git@github.com
7. 重新尝试 git clone

按照上述步骤操作后,重新运行 git clone 命令,此时应该能够正常克隆仓库:

代码语言:javascript
复制
git clone git@github.com:username/repository.git

此时,Git 连接应该没有问题,并且可以顺利完成上传和下载操作。

Git clone
Git clone
总结

通过以上步骤,解决了 GitHub 的 Permission denied (publickey) 错误。主要步骤包括生成 SSH 密钥、将公钥添加到 GitHub 账户以及测试 SSH 连接等。按照这些操作后,你应该能够顺利使用 SSH 协议进行 Git 操作。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-07-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 测试 SSH 连接是否成功
  • 2. Permission Denied (publickey) 错误解析
  • 3. 检查 SSH 密钥是否已生成
  • 4. 将 SSH 公钥添加到 GitHub
  • 5. 测试 SSH 连接
  • 6. 确保使用正确的 SSH 密钥
  • 7. 重新尝试 git clone
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档