为 Github 创建本地 .ssh 关联 (RSA 以支持老系统)

生成 SSH 密钥对

打开终端(Linux/macOS)或 Git Bash(Windows),运行以下命令生成 RSA 密钥对:

bash 复制代码
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
  • -t rsa 指定密钥类型为 RSA。
  • -b 4096 设置密钥长度为 4096 位(兼容老系统可降低至 2048)。
  • -C 添加注释(通常为邮箱)。

按提示选择密钥存储路径(默认 ~/.ssh/id_rsa)和设置密码(可选)。

将 id_rsa 添加到 SSH Agent 的方法

检查 SSH Agent 是否运行

运行以下命令确认 SSH Agent 是否已在后台运行:

bash 复制代码
eval "$(ssh-agent -s)"

若输出类似 Agent pid 12345 表示 Agent 正在运行。

添加私钥到 SSH Agent

使用 ssh-add 命令添加私钥文件(默认路径为 ~/.ssh/id_rsa):

bash 复制代码
ssh-add ~/.ssh/id_rsa

若私钥有密码保护,会提示输入密码。

验证添加结果

通过以下命令查看已加载的密钥列表:

bash 复制代码
ssh-add -l

输出应显示密钥指纹和对应的注释(如 id_rsa)。

将公钥添加到 GitHub

复制公钥内容(默认路径 ~/.ssh/id_rsa.pub):

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

登录 GitHub,进入 Settings → SSH and GPG keys → New SSH key,粘贴公钥并保存。

测试 SSH 连接

运行以下命令验证配置:

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

若提示 You've successfully authenticated 则关联成功。

配置 Git 使用 SSH

若之前使用 HTTPS 克隆仓库,需更新远程 URL:

bash 复制代码
git remote set-url origin git@github.com:username/repo.git

替换 username/repo 为实际仓库路径。

解决兼容性问题

若遇到老系统不支持新格式,可改用传统 PEM 格式生成密钥:

bash 复制代码
ssh-keygen -m PEM -t rsa -b 2048
  • -m PEM 强制使用 PEM 格式(兼容旧版 OpenSSH)。

多密钥管理

若需为不同账户配置多密钥,编辑 ~/.ssh/config 文件:

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

克隆时使用别名:

bash 复制代码
git clone git@github.com-user1:username/repo.git

解决常见问题

密钥权限问题

确保私钥文件权限为 600,目录权限为 700

bash 复制代码
chmod 600 ~/.ssh/id_rsa
chmod 700 ~/.ssh

自动启动 SSH Agent

~/.bashrc~/.zshrc 中添加以下内容实现登录时自动启动 Agent:

bash 复制代码
if [ -z "$SSH_AUTH_SOCK" ]; then
   eval "$(ssh-agent -s)"
   ssh-add ~/.ssh/id_rsa
fi

指定其他密钥路径

若密钥不在默认路径,需指定完整路径:

bash 复制代码
ssh-add /path/to/custom_key
相关推荐
鹏毓网络科技1 天前
Cursor Rules 文件配置实战:3 个隐藏参数让我每月少写 40% 样板代码
前端·github
乘云数字DATABUFF1 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
嘻嘻仙人2 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
白鲸开源2 天前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
白鲸开源2 天前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github
徐小夕3 天前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github
码流怪侠3 天前
【GitHub】Ponytail:给 AI 编码代理植入“懒人资深开发者“灵魂的开源插件深度拆解
程序员·github·ai编程
齐翊3 天前
怎么确认 AI 看懂了你的提示词?
人工智能·github·ai编程
Web3探索者3 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
荣--3 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计