使用 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。

相关推荐
WebInfra4 小时前
Rspack 1.5 发布:十大新特性速览
前端·javascript·github
qq_441996056 小时前
SSH 反向隧道:快速解决服务器网络限制
服务器·网络·ssh
SelectDB8 小时前
湖仓一体:小米集团基于 Apache Doris + Apache Paimon 实现 6 倍性能飞跃
数据库·开源·github
NocoBase11 小时前
5 个最佳 ServiceNow 开源替代品(含价格对比)
低代码·开源·github
绝无仅有12 小时前
常用 Kubernetes (K8s) 命令指南
后端·面试·github
云心雨禅13 小时前
VPS一键测试脚本NodeQuality,无痕体验+自动导出,服务器测试更轻松
运维·服务器·github
uhakadotcom13 小时前
如何安装和使用开源的Meilisearch
后端·面试·github
研來如此13 小时前
Git连接Github远程仓库的代理设置
git·github
Danileaf_Guo15 小时前
华为交换机S3700/S5700/CE6800配置SSH远程登录
运维·华为·ssh