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。

相关推荐
散峰而望8 小时前
【基础算法】从入门到实战:递归型枚举与回溯剪枝,暴力搜索的初级优化指南
数据结构·c++·后端·算法·机器学习·github·剪枝
好像不对劲8 小时前
【docker】win10 wsl docker不能挂GPU
运维·docker·容器·wsl
落日漫游9 小时前
MySQL双活与备份:高可用实战指南
运维
江畔何人初9 小时前
Docker、containerd、CRI、shim 之间的关系
运维·docker·云原生·容器·kubernetes
Refly10 小时前
【微信接入 OpenClaw 龙虾🦞】10分钟手把手教程完成接入,Claude 模型无限使用
前端·微信·github
idolao11 小时前
CentOS 7 安装 nginx-1.3.15.tar.gz 详细步骤(从源码编译到启动配置)
linux·运维·数据库
CDN36011 小时前
低成本游戏防护:360 SDK 游戏盾使用总结
运维·游戏·网络安全
万象.11 小时前
docker镜像仓库
运维·docker·容器
老星*11 小时前
Lucide Icons:开源、轻量、设计师友好的现代图标库
ui·开源·github
rosmis11 小时前
自动化文献检索与下载工作流:基于 Playwright 的 RPA 实践方案
运维·自动化·rpa