SSH, GitHub

SSH 是什么?

SSH(Secure Shell,安全外壳协议) 是一种用于安全远程登录安全文件传输的网络协议。它加密所有通信,防止窃听和中间人攻击。

SSH 的核心概念:

1. 身份验证机制

SSH 使用两种主要的身份验证方式:

  • 密码认证:输入用户名和密码
  • 密钥认证:使用加密密钥对,这是你在课程中要做的

2. SSH 密钥对

每个 SSH 密钥由两部分组成:

  • 私钥(Private Key) :保存在你的电脑/容器中,绝不共享

  • 公钥(Public Key):可以安全地分享给任何人(如 GitHub)

    你的私钥(本地) ↔ 别人的公钥(远程)

在你的课程场景中:

当你执行"在 Docker 容器内创建 SSH 密钥,添加到 GitHub,然后克隆仓库"时:

步骤分解:

bash 复制代码
# 1. 在Docker容器中生成SSH密钥对
ssh-keygen -t ed25519 -C "your-email@example.com"
# 这会创建两个文件:
# - ~/.ssh/id_ed25519      (私钥,保密!)
# - ~/.ssh/id_ed25519.pub  (公钥,可公开)

# 2. 将公钥添加到GitHub账户
cat ~/.ssh/id_ed25519.pub
# 复制输出内容,粘贴到GitHub Settings → SSH and GPG keys

# 3. 克隆仓库使用SSH协议
git clone git@github.com:username/repository.git
# 而不是使用HTTPS:
# git clone https://github.com/username/repository.git

为什么用 SSH 而不是 HTTPS?

SSH 方式 HTTPS 方式
git@github.com:user/repo.git https://github.com/user/repo.git
使用密钥认证,无需每次输入密码 需要输入用户名/密码或使用token
更安全,适合自动化脚本 更方便,但密码可能被缓存
端口22,可能被防火墙阻挡 端口443,通常开放

SSH 的工作原理(类比):

想象你要进入一个高度安全的建筑:

密码方式(传统):

  1. 走到门口
  2. 输入用户名和密码
  3. 门卫检查密码是否正确
  4. 如果正确,让你进入

SSH密钥方式(现代):

  1. 你有一把特殊的私人钥匙(私钥)
  2. 建筑管理员有一把对应的公共锁(公钥)
  3. 你把私钥插入锁中
  4. 如果匹配,门自动打开
  5. 优势:即使有人偷看了锁(公钥),也无法复制你的私钥

在容器中使用 SSH 的特殊考虑:

bash 复制代码
# Docker 容器是临时的,所以:
# 1. 要么每次启动容器都重新生成密钥(不推荐)
# 2. 要么将 ~/.ssh 目录挂载到容器中(推荐)

# 推荐方法:挂载主机的SSH密钥到容器
docker run -v ~/.ssh:/root/.ssh:ro your-image
# :ro 表示只读,防止容器修改你的私钥

实际命令示例:

bash 复制代码
# 在Docker容器内:
# 1. 生成SSH密钥
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
# 直接按回车接受默认位置和空密码

# 2. 启动SSH代理
eval "$(ssh-agent -s)"

# 3. 将私钥添加到代理
ssh-add ~/.ssh/id_rsa

# 4. 查看公钥并复制
cat ~/.ssh/id_rsa.pub

# 5. 添加到GitHub后测试连接
ssh -T git@github.com
# 应该看到:Hi username! You've successfully authenticated...

# 6. 克隆仓库
git clone git@github.com:username/repo-name.git

安全提醒:

  1. 私钥如同密码 :永远不要分享 id_rsa 文件
  2. 公钥可以公开id_rsa.pub 文件可以安全地给任何人
  3. 容器是临时的:如果容器被删除,里面的密钥也会丢失
  4. 考虑密钥管理:对于生产环境,使用专门的密钥管理工具

总结:

SSH 是一种安全的通信协议 ,而 SSH 密钥是一种更安全、更方便的身份验证方式,特别适合:

  • 自动化脚本(无需人工输入密码)
  • 持续集成/持续部署(CI/CD)
  • 服务器管理
  • GitHub/GitLab 等代码托管平台的认证

在你的课程练习中,使用 SSH 密钥可以让 Docker 容器安全地访问你的 GitHub 仓库,而不需要每次输入密码或 token。

相关推荐
馨谙15 分钟前
shell编程实际应用----磁盘空间监控与告警
linux·运维·服务器
UP_Continue39 分钟前
Linux--命令行参数和环境变量
linux·运维·服务器
重生之绝世牛码43 分钟前
Linux软件安装 —— PostgreSQL高可用集群安装(postgreSQL + repmgr主从复制 + keepalived故障转移)
大数据·linux·运维·数据库·postgresql·软件安装·postgresql高可用
STCNXPARM1 小时前
Linux PCI/PCIe子系统深度剖析
linux·运维·服务器·pci/pcie
EverydayJoy^v^2 小时前
RH134学习进程——八.管理存储堆栈
linux·运维·服务器
夕除3 小时前
java--1
linux·运维·服务器
桌面运维家3 小时前
vDisk VOI桌面安全策略怎么配置?详细教程
运维·网络
重生之绝世牛码3 小时前
Linux软件安装 —— ClickHouse单节点安装(rpm安装、tar安装两种安装方式)
大数据·linux·运维·数据库·clickhouse·软件安装·clickhouse单节点
CoderJia程序员甲3 小时前
GitHub 热榜项目 - 日榜(2026-01-24)
git·ai·开源·llm·github
莫问前路漫漫3 小时前
Electerm 连接远程服务器完整指南
运维·服务器·git