ssh配置(一、GitLabGitHub)

一. 为什么配置ssh

  • 使用 ssh 克隆项目,更加安全方便。 git clone 项目时一般使用两种协议 httpsssh

二. 原理的通俗解释

  1. ssh 解决的问题是登录时的用户身份验证问题,默认使用 RSA(也支持其他算法: RSA、DSA、ECDSA、EdDSA、Ed25519 ,它们在效率,安全性上有所区别)。
  2. 完整的流程:
  • 我们首先在本地生成一对公私钥(如果需要多对秘钥分别用于不同平台 gitlab, github, gitee 等,可以生成多对;也可以多个平台使用一对秘钥),
  • 私钥交给秘钥管理器 ssh-agent
  • 公钥配置到目标网站 gitlab, github,gitee
  • 这样在登录指定服务器时,秘钥管理器就会使用秘钥自动验证用户身份。
  1. 建议
  • 使用两对秘钥,一个用于公司的gitlab,一个用于自己的 gitee, github。

三. 相关文件

  • 所有 ssh 相关的文件都在 ~/.ssh/ 下,本次用到的相关文件
    1. id_rsaid_rsa.pub :默认一对公私钥的名字,可以有多对,使用命令 ssh-keygen 生成。
    2. known_hosts :当替换了原有平台的公钥时,需要去这个文件里删除对应平台的 host 记录。

四. 关键步骤

  1. 生成秘钥对,可以检查目录 ~/.ssh/ 下是否有秘钥对,如果没有则重新生成。
bash 复制代码
# 给 邮箱zhangsan@qq.com 或 用户lisi 生成公私钥
# -t 参数:指定算法 ed25519,更加高效和安全
# -C 参数:指定公私钥中的注释,一般用邮箱或用户名,不影响使用
ssh-keygen -t ed25519 -C "zhangsan@qq.com"
ssh-keygen -t ed25519 -C "lisi"
# 输入命令后,如果不需要密码的话,连续3个回车。最后得到了两个文件:id_rsa和id_rsa.pub。
# 如果需要指定当前秘钥给 gitlab 平台,在第一次回车后,复制提示的路径,修改 id_rsa 为 gitlab_id ,
# 则会得到 gitlab_id 和 gitlab_id.pub 两个文件。
  1. 添加私钥到 ssh-agent 私钥管理器。
bash 复制代码
# 查看当前已经添加的 秘钥
ssh-add -l
# 添加指定的 秘钥,不要添加公钥
ssh-add ~/.ssh/id_rsa
ssh-add ~/.ssh/gitlab_id
# 如果发现本地 ssh-add 没有的话,就先运行如下命令
eval  `ssh-agent -s`
  1. 添加公钥到 gitlab、github、gitee
  • 复制 gitlab_id.pub 文件里的内容,黏贴到对应网站的个人配置中。
  1. 验证是否可以克隆。
bash 复制代码
# 验证是否可以连接目标服务器,验证格式:ssh -T git@domain。
# domain 是克隆项目时 git@domain:project 之间的内容。
ssh -T git@gitlab.company.com
ssh -T git@gitee.com
ssh -T git@github.com
# 直接克隆项目代码试试
git clone git@xxx.git

五. 命令总结

bash 复制代码
# 生成秘钥
ssh-keygen -t ed25519 -C "zhangsan@qq.com"
# 查看添加秘钥到 管理器
ssh-add -l
ssh-add ~/.ssh/id_rsa
# 运行管理器
eval  `ssh-agent -s`
# 验证是否可以访问
ssh -T git@gitee.com

六. windows 10 需要注意以下两点

  1. 在 服务 中开启 ssh agent。
  • win + R -> services.msc -> openssh -> auto
  1. 如果执行 ssh -T git@gitee.com 可以,但是仍不能 克隆 代码,需要配置 config 文件。
相关推荐
Alex艾力的IT数字空间3 分钟前
大模型的“Think 模式”(思考模式)关闭的配置方式
人工智能·机器人·web3·github·开源软件·量子计算·开源协议
带娃的IT创业者1 小时前
GitHub Copilot 计费模式大变革:深度解析按量计费时代的技术实现与成本优化
github·copilot·ai编程·成本优化·github copilot·计费模式·按量计费
YaBingSec1 小时前
玄机网络安全靶场:GeoServer XXE 任意文件读取(CVE-2025-58360)
java·运维·网络·安全·web安全·tomcat·ssh
SiYuanFeng2 小时前
GitHub 仓库如何添加 Topic
github
豆豆14 小时前
网站管理系统大全:精选开源与商业CMS系统全面指南
github·cms·建站系统·建站·建站平台·内容管理系统·网站管理系统
用户794572239541316 小时前
一句话生成短视频:当 AI Skills 真正打通"创作流水线"
人工智能·github·ai编程
甄心爱学习17 小时前
【项目实训】法律文书智能摘要系统4
python·github·个人开发
河婆墟邓紫棋17 小时前
MIUI中的权限
android·github
OpenTiny社区18 小时前
GenUI SDK 生成式UI:六大开发特性详解,适配多种业务场景
前端·github·ai编程
Eloudy19 小时前
迁移带有 git lfs 功能的 github 仓库
git·github