使用 SSH 连接 GitHub

一、生成 SSH 密钥

打开终端(命令行)并输入:

bash 复制代码
ssh-keygen -t rsa -b 4096 -C "你的GitHub邮箱"
  • 会提示保存路径,一般按回车即可(默认路径是 ~/.ssh/id_rsa)。
  • 会让你输入密码,可以留空(或设置一把密码保护)。

生成成功后,会看到:

text 复制代码
Your identification has been saved in /home/you/.ssh/id_rsa.
Your public key has been saved in /home/you/.ssh/id_rsa.pub.

📋 二、复制公钥

复制公钥内容(id_rsa.pub 文件):

bash 复制代码
cat ~/.ssh/id_rsa.pub

复制输出的那一整行内容(以 ssh-rsa 开头)。

三、添加 SSH 公钥到 GitHub

  1. 登录 GitHub官网。

  2. 点击右上角头像 → Settings。

  3. 左侧导航栏选择 SSH and GPG keys。

  4. 点击 "New SSH key"。

  5. 输入标题(比如 "My Laptop"),并粘贴刚才复制的公钥内容。

  6. 点击 "Add SSH key"。

四、测试 SSH 是否成功连接

在终端中运行:

bash 复制代码
ssh -T git@github.com

第一次会问是否继续连接,输入 yes。

成功的话会显示:

text 复制代码
Hi your-username! You've successfully authenticated, but GitHub does not provide shell access.

五、使用 SSH 克隆仓库

用 SSH 地址而不是 HTTPS 地址:

bash 复制代码
git clone git@github.com:你的用户名/你的仓库名.git

比如:

bash 复制代码
git clone git@github.com:johnsmith/my-private-repo.git

六、切换已存在仓库为 SSH 方式(可选)

如果你一开始用了 HTTPS,可以这样切换为 SSH:

bash 复制代码
cd 仓库目录
git remote set-url origin git@github.com:你的用户名/你的仓库名.git

七、后续上传(无需再输入用户名密码)

以后提交代码时只需:

bash 复制代码
git add .
git commit -m "更新说明"
git push

不会再要求输入用户名或密码。

异常

git push -u origin develop

fatal: unable to access 'https://github.com/xxx.git/': OpenSSL SSL_read: Connection was reset, errno 10054

表明 Git 在通过 HTTPS 方式连接 GitHub 时连接被重置。这个通常是由以下原因造成的:

  1. ✅ 建议改用 SSH(最推荐)
    如果你已经配置过 SSH(参见上一步的 SSH 教程),直接改 remote 为 SSH 地址,问题通常就解决了:
bash 复制代码
git remote set-url origin git@github.com:xxx/xxx.git

然后再执行:

bash 复制代码
git push -u origin develop

ssh -T git@github.com

git@github.com: Permission denied (publickey).

说明你的 Git 正在尝试使用 SSH 连接 GitHub,但 GitHub 没有找到匹配的 SSH 公钥。

一、确认是否生成了 SSH 密钥

执行以下命令,检查密钥是否存在:

bash 复制代码
ls ~/.ssh

你应该能看到如下文件:

nginx 复制代码
id_rsa       # 私钥
id_rsa.pub   # 公钥

如果没有,就生成一对:

bash 复制代码
ssh-keygen -t rsa -b 4096 -C "你的GitHub邮箱"

一路回车即可。

二、将公钥添加到 GitHub

三、确认 SSH Agent 正常运行并加载密钥(Linux/macOS)

bash 复制代码
eval "$(ssh-agent -s)"
ssh-add ~/.ssh/id_rsa

如果是 Windows Git Bash,也可以运行上面这两行。

四、测试是否成功连接

bash 复制代码
ssh -T git@github.com

如果配置正确,会显示:

vbnet 复制代码
Hi your-username! You've successfully authenticated, but GitHub does not provide shell access.

五、如果你用了多个密钥(高级)

你可以创建 ~/.ssh/config 文件指定 GitHub 使用哪个密钥:

bash 复制代码
nano ~/.ssh/config   # 或用你喜欢的编辑器

添加以下内容:

bash 复制代码
Host github.com
  HostName github.com
  User git
  IdentityFile ~/.ssh/id_rsa

保存后,再次测试连接。

最后一步:确认远程仓库使用的是 SSH 地址

bash 复制代码
git remote set-url origin git@github.com:你的用户名/你的仓库名.git

git push

fatal: The current branch develop has no upstream branch.

To push the current branch and set the remote as upstream, use

git push --set-upstream origin develop

这个提示是因为你当前的 develop 分支 还没有关联远程分支,所以 Git 不知道要把它推到哪里。

解决方法

运行下面这条命令即可设置 origin 为 develop 分支的上游:

bash 复制代码
git push --set-upstream origin develop

之后你就可以直接使用:

bash 复制代码
git push

来提交了,无需再加任何参数。

背景解释

git push 其实是这样理解的:

  • 如果你第一次推送某个新分支(如 develop),Git 不知道它应该对应远程的哪个分支。

  • 所以你要用 --set-upstream 明确告诉 Git:这个分支的"上游"就是 origin/develop。

  • 一旦设置后,Git 会记住,以后 git pull 和 git push 就默认用这个远程分支了。

小提示:你也可以用简写命令

bash 复制代码
git push -u origin develop

-u 等价于 --set-upstream。

相关推荐
James_WangA1 天前
我给 AOI 设备装了一个 Agent,然后发现工具注册才是最难写的
架构·github
James_WangA1 天前
产线上跑 Agent:LLM 挂了不是 500 错误,是停线
架构·github
Hommy881 天前
【开源剪映小助手】字幕接口
开源·github·aigc·剪映小助手·视频剪辑自动化
一袋米扛几楼982 天前
【Git】规范化协作:详解 GitHub 工作流中的 Issue、Branch 与 Pull Request 最佳实践
前端·git·github·issue
尘埃落定wf2 天前
# GitHub CLI:告别繁琐的 Git 命令,让开发更高效
git·github
zh_xuan2 天前
上传api调试工具到github
github
AIMath~2 天前
彻底删除 GitHub 仓库中特定文件夹的完整指南
github
DogDaoDao2 天前
【GitHub】OpenClaw:开源个人AI助手的新标杆
人工智能·深度学习·开源·大模型·github·ai编程·opeclaw
魔极客2 天前
第十二节:龙晰 AnolisOS-23.4-x86_64.qcow2 虚拟机的网络配置方式及 ssh 连接
网络·ssh·php
一点一木2 天前
🚀 2026 年 4 月 GitHub 十大热门项目排行榜 🔥
人工智能·github