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。

相关推荐
fantasy5_51 天前
Linux 调试利器:GDB 全面操作指南
linux·运维·服务器
学生董格1 天前
[开源工具]windows使用linux-tftp:tftpd64第三方库
linux·运维·服务器
努力努力再努力wz1 天前
2025年度总结:不断迈出第一步
linux·运维·服务器·数据结构·redis·python·django
lbb 小魔仙1 天前
【Linux】嵌入式 Linux 从入门到精通:设备树配置 + 驱动优化核心教程
linux·运维·服务器
是毛毛吧1 天前
AI开发工具----碾压 Bolt.new?Lovable:全栈开发的下一个“卷王”级神器深度评测
人工智能·开源·github
QT 小鲜肉1 天前
【Linux命令大全】003.文档编辑之comm命令(实操篇)
linux·运维·服务器·javascript·chrome·笔记
Elastic 中国社区官方博客1 天前
Elasticsearch:在 Streams 中使用 ML 自动化 log 解析
大数据·运维·elk·elasticsearch·搜索引擎·自动化·全文检索
Microsoft Word1 天前
Linux零基础入门
linux·运维·服务器
QT 小鲜肉1 天前
【Linux命令大全】002.文件传输之lpd命令(实操篇)
linux·运维·服务器·网络·chrome·笔记