GitHub 多账号生存指南:从 SSH 连接到 GPG 签名全流程

在同一台电脑上管理多个 GitHub 账号(如个人号Account_A和私有项目号 Account_B)时,核心挑战在于权限隔离与身份验证。本文将带你完成一套物理隔离、身份明确的开发环境配置。


文章目录

    • [一、 生成 SSH 密钥:开启权限的大门](#一、 生成 SSH 密钥:开启权限的大门)
      • [1. 为两个账号生成独立的 Ed25519 密钥](#1. 为两个账号生成独立的 Ed25519 密钥)
      • [2. 将公钥关联至 GitHub 账号](#2. 将公钥关联至 GitHub 账号)
    • [二、 配置 SSH 路由隔离:多账号的核心逻辑](#二、 配置 SSH 路由隔离:多账号的核心逻辑)
    • [三、 GPG 双签名配置:获取 Verified 勋章](#三、 GPG 双签名配置:获取 Verified 勋章)
      • [1. 生成两套 GPG 密钥](#1. 生成两套 GPG 密钥)
      • [2. 导出并关联 GitHub](#2. 导出并关联 GitHub)
    • [四、 实战:克隆项目与仓库身份锁定](#四、 实战:克隆项目与仓库身份锁定)
      • [1. 使用别名 Clone 项目](#1. 使用别名 Clone 项目)
      • [2. 仓库内的"身份三板斧"](#2. 仓库内的“身份三板斧”)

一、 生成 SSH 密钥:开启权限的大门

原理:SSH 采用非对称加密。你生成一对密钥,将"公钥"交给 GitHub,自己留着"私钥"。

1. 为两个账号生成独立的 Ed25519 密钥

Ed25519 是目前推荐的算法,比 RSA 更安全、更轻量。当然,也可以用RSA。

为账号 A 生成

bash 复制代码
ssh-keygen -t ed25519 -C "user_a@email.com" -f ~/.ssh/id_ed25519_account_a

为账号 B 生成

bash 复制代码
ssh-keygen -t ed25519 -C "user_b@email.com" -f ~/.ssh/id_ed25519_account_b

提示:建议设置 Passphrase(密码)以增强私钥安全性,当然,也可以不做设置。

2. 将公钥关联至 GitHub 账号

分别登录两个 GitHub 账号:

1.运行cat ~/.ssh/id_ed25519_account_a.pub查看并复制公钥内容。同理可查看id_ed25519_account_b

  1. 登录 GitHub -> Settings ->SSH and GPG keys-> New SSH key。

  2. 粘贴内容并保存。


二、 配置 SSH 路由隔离:多账号的核心逻辑

原理:修改~/.ssh/config,通过"别名(Alias)"强制指定连接不同仓库时使用哪把私钥。

可直接输入命令行在~/.ssh目录下创建或修改一个名为config的文件(无后缀):

bash 复制代码
# 编辑 config 文件
nano ~/.ssh/config

在文件中写入以下内容,通过Host 别名来区分

也可以手动编辑或创建~/.ssh/config

plain 复制代码
# 账号 A 别名 (个人/老号)
Host github-a
    HostName github.com
    User git
    IdentityFile ~/.ssh/id_ed25519_account_a

# 账号 B 别名 (工作/新号)
Host github-b
    HostName github.com
    User git
    IdentityFile ~/.ssh/id_ed25519_account_b

测试连接

bash 复制代码
ssh -T git@github-a
ssh -T git@github-b
# 看到 "Hi [Username]! You've successfully authenticated" 即为成功。

三、 GPG 双签名配置:获取 Verified 勋章

原理 :SSH 负责推送权限,GPG 负责内容防伪。GitHub 会校验git config中的邮箱、GPG 密钥邮箱以及账号验证邮箱是否三位一体。

前置条件:下载Gpg4win,下载过程中只需要勾选这一个即可。

1. 生成两套 GPG 密钥

bash 复制代码
gpg --full-generate-key
  • 配置 :选择 (9) ECC (EdDSA) -> (1) Curve 25519 -> 0 (永不过期)
  • 账号 A :使用 user_a@email.com
  • 账号 B :使用 user_b@email.com

2. 导出并关联 GitHub

bash 复制代码
# 获取 Key ID (取 [SC] 前的 16 位字符)
gpg --list-secret-keys --keyid-format=LONG
# 输出中 sec 这一行 / 后面的字符串就是你的 KeyID(例如:4AB5C343725679D2)。


# 导出公钥并贴入 GitHub 的 GPG keys 页面
gpg --armor --export [Your_Key_ID]

四、 实战:克隆项目与仓库身份锁定

1. 使用别名 Clone 项目

必须 手动修改 GitHub 提供的 URL,将 github.com 替换为你在 Config 中定义的别名。

bash 复制代码
# 错误示范:git clone git@github.com:username/private-repo.git
# 正确示范:使用账号 B 的别名拉取私有仓库
git clone git@github-b:username/private-repo.git

2. 仓库内的"身份三板斧"

进入仓库目录,执行局部配置以覆盖全局设置,防止身份泄露:

bash 复制代码
cd private-repo

# 1. 锁定该仓库的提交邮箱 (必须与该账号的 GPG 密钥一致)
git config --local user.email "user_b@email.com"

# 2. 锁定该仓库使用的 GPG Key ID
git config --local user.signingkey [Key_ID_B]

# 3. 开启自动签名
git config --local commit.gpgsign true

如果未设置全局配置,系统会提醒你,但尽量不设置--global全局设置,以防在忘记进行局部配置的情况下,默认执行全局设置。


遵循这套流程,你就能在一台机器上完美驾驭多个 GitHub 身份,同时确保每个提交都具有不可篡改的专业背书。

相关推荐
Frank_refuel8 小时前
Linux操作系统 - > 进程信号(中)
linux·运维·服务器
阿杜杜不是阿木木8 小时前
authentik开源身份认证与管理平台-与 Jenkins 集成(5)
运维·servlet·jenkins·authing·authentik
minji...9 小时前
Linux 多线程(二)进程虚拟地址空间&&页表&&物理地址
linux·运维·服务器
irpywp9 小时前
Boneyard:基于组件映射的骨架屏方案
前端·ui·github
liqianpin19 小时前
Nginx WebSocket 长连接及数据容量配置
运维·websocket·nginx
IMPYLH9 小时前
Linux 的 link 命令
linux·运维·服务器·bash
m0_6948455710 小时前
RevelGo搭建教程:类Rails开发体验的Go Web框架
服务器·开发语言·后端·docker·golang·开源·github
蛐蛐蛐10 小时前
在Ubuntu上重新安装OpenClaw报错的一种解决方法
linux·运维·ubuntu·openclaw
无忧智库10 小时前
国家级垂直行业大模型高质量语料库精炼与自动化标注底座建设方案(WORD)
运维·自动化