如何在多个 Git 平台玩转一个堆栈

铁佛  金牌会员 | 2024-5-22 08:13:54 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 793|帖子 793|积分 2379


版本控制在软件开发中至关重要,而 Git 是广泛使用的代码管理工具。偶然,我们可能需要在多个平台  (如 GitHubGitLabGitee) 上同步同一 Git 堆栈,以便备份、协作等。
本文将带你玩转此操作,其中关键是“配置 SSH” 和“远程堆栈”。起首,我们来讲述 SSH 的配置。
配置 SSH

为确保安全和简化登录,需配置 SSH 密钥。SSH 密钥是用于身份验证的安全方式,可免密访问远程 Git 堆栈。
查抄现有 SSH 密钥

在生成新的 SSH 密钥之前,应该查抄本地电脑是否存在现有密钥。打开终端,输入一下下令以检察是否存在现有的 SSH 密钥。
  1. ls -al ~/.ssh
复制代码
此下令将列出 .ssh 目录中的所有文件(如果存在)。如果没有想要的,需要创建新的 SSH 密钥对。
生成新 SSH 密钥

在本地电脑上生成新的 SSH 密钥。 生成密钥后,可将公钥添加到 GitHub 等平台上的帐户中,以便通过 SSH 为 Git 操作启用身份验证。
打开终端输入一下下令,然后一起 Enter 键,完成密钥对的生成:
  1. ssh-keygen -t ed25519 -C "your_email@example.com" -f ~/.ssh/id_github
复制代码
在这个下令中:

  • ssh-keygen 用于生成、管理和转换认证密钥的工具。
  • -t 指定了密钥类型。ed25519 是一种现代的、安全的公钥加密算法,被广泛认为是非常强大且高效的。与 RSA 和 DSA 密钥相比,它提供了更好的安全性和性能。
  • -C 指定一个注释,通常是用户的电子邮件地址。
  • -f 指定了密钥文件的保存位置和名称。默认环境下,ssh-keygen 会生成名为 id_rsa、id_ed25519 等的文件,具体取决于所选的密钥类型。在这里,它将被保存为 ~/.ssh/id_github (私钥) 和 ~/.ssh/id_github.pub (公钥)。
相关链接:
编辑 ~/.ssh/config 文件

为了在一台电脑上配置多个平台的 SSH,你需要编辑 ~/.ssh/config 文件。以下是一个配置示例,分别配置了 GitHubGitLabGitee 的 SSH:
  1. # GitHub 配置
  2. Host github.com
  3.     HostName github.com
  4.     User git
  5.     IdentityFile ~/.ssh/id_github
  6.     PreferredAuthentications publickey,password  # 优先使用 SSH 公钥认证,然后再尝试用户名和密码认证
  7.     IdentitiesOnly yes
  8. # GitLab 配置
  9. Host gitlab.com
  10.     HostName gitlab.com
  11.     User git
  12.     IdentityFile ~/.ssh/id_gitlab
  13.     PreferredAuthentications publickey  # 仅使用 SSH 公钥认证
  14.     IdentitiesOnly yes
  15. # Gitee 配置
  16. Host gitee.com
  17.     HostName gitee.com
  18.     User git
  19.     IdentityFile ~/.ssh/id_gitee
  20.     PreferredAuthentications publickey  # 仅使用 SSH 公钥认证
  21.     IdentitiesOnly yes
复制代码
在这个配置中:

  • Host 是你定义的别名,可以随意命名,但通常使用服务域名以方便记忆。
  • HostName 是实际的服务域名。
  • User 通常是 git,因为这是大多数 Git 服务器的默认用户名。
  • IdentityFile 指向你的私钥文件路径。
  • PreferredAuthentications 指定 SSH 客户端在尝试身份验证时应优先思量的认证方法列表。例如,你可以设置为只使用公钥认证,或者优先使用公钥认证,然后再尝试其他 (密码) 认证方式。
  • IdentitiesOnly yes 指示 SSH 只使用 IdentityFile 指定的身份进行认证,这有助于制止 SSH 代理或默认私钥的干扰。
新增 SSH 密钥到平台帐户

配置 ~/.ssh/config 文件完毕后,必须将 SSH 公钥添加到 GitHubGitLabGitee,才能为帐户启用 SSH 访问。
相关链接:
测试 SSH 毗连

设置 SSH 密钥并将其添加到 GitHubGitLabGitee 后,可以测试毗连。
测试 SSH 毗连之前,应已完成以上所有步调。
打开终端,输入以下下令:
  1. ssh -T git@github.com          # 测试 Github 的 SSH 连接
  2. ssh -T git@gitlab.example.com  # 测试 Gitlab 的 SSH 连接。注意:要将 gitlab.example.com 替换为你的实例 URL
  3. ssh -T git@gitee.com           # 测试 Gitee 的 SSH 连接
复制代码
如果这是你第一次毗连,你应该会看到雷同以下消息,提示你需要验证平台主机的真实性:
  1. > The authenticity of host ' (IP ADDRESS)' can't be established.
  2. > ED25519 key fingerprint is SHA256:+DiY3wvvV6TuJJhbpZisF/zLDA0zPMSvHdkr4UvCOqU.
  3. > Are you sure you want to continue connecting (yes/no)?
复制代码
输入 yes,然后按 Enter。
  1. > Hi USERNAME! You've successfully authenticated, but GitHub does not
  2. > provide shell access.
复制代码
添加成功后,就可以使用 SSH 协议访问这些平台了。例如,你可以使用 git clone <远程仓库URL>git@github.com/username/repository.git 来克隆 GitHub 上的堆栈,SSH 会根据 ~/.ssh/config 文件中的配置来选择合适的私钥进行身份验证。
相关链接:
我们为电脑配置完 SSH 后,接下来为本地 Git 堆栈添加多个远程平台的堆栈链接。
配置远程堆栈

没有 Git 堆栈

为 Git 堆栈添加多个远程平台的堆栈的前提是得有个本地 Git 堆栈。如果你还没有,可以用以下下令初始化一个。
  1. cd your_folder
  2. git init --initial-branch=main
复制代码
已经有 Git 堆栈

如果你已经在其中一个平台上有个 Git 堆栈,你可以使用以下下令将其克隆到本地。
  1. git clone <远程仓库URL>
复制代码
然后,cd 到新初始化、或者克隆下来的堆栈目录,添加其他平台的远程堆栈链接
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

铁佛

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表