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。

相关推荐
威迪斯特1 天前
CentOS图形化操作界面:理论解析与实践指南
linux·运维·centos·组件·图形化·桌面·xserver
一方热衷.1 天前
在线安装对应版本NVIDIA驱动
linux·运维·服务器
独自归家的兔1 天前
ubuntu系统安装dbswitch教程 - 备份本地数据到远程服务器
linux·运维·ubuntu
m0_694845571 天前
tinylisp 是什么?超轻量 Lisp 解释器编译与运行教程
服务器·开发语言·云计算·github·lisp
ONE_SIX_MIX1 天前
ubuntu 24.04 用rdp连接,桌面黑屏问题,解决
linux·运维·ubuntu
龙飞051 天前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
June`1 天前
muduo项目排查错误+测试
linux·c++·github·muduo网络库
春日见1 天前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡1 天前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器
消失的旧时光-19431 天前
Linux 编辑器入门:nano 与 vim 的区别与选择指南
linux·运维·服务器