由于项目要求,需要经常从github上克隆镜像,本地网络不是特别稳定的话,https很容易挂,而ssh相对比较稳定。故本文通过已有的ssh公私钥,实现docker从github的ssl链接进行克隆。
1.生成公私钥
随便找一台ubuntu系统的电脑运行如下代码:
bash
ls -al ~/.ssh
apt-get update
apt-get -y install openssh-server
#一路回车
ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
文件在~/.ssh目录,生成四个文件

2.配置github
bash
# 复制所有内容到剪切板
cat ~/.ssh/id_rsa.pub
-
登录 GitHub。
-
前往 Settings > SSH and GPG keys。
-
点击 New SSH key,粘贴公钥内容并保存。
bash
# 测试连通性
ssh -T git@github.com
# 会显示下面内容
# Hi username! You've successfully authenticated, but GitHub does not provide shell access.
# 使用ssh克隆username的imagename镜像到本地/host/path目录
# git clone -b main git@github.com:username/imagename.git /host/path
3.其他用户配置
如上所述,普通用户a已经配置完成,尚需配置root用户,使其能复用用户a的公私钥进行ssh传输
bash
# 创建.ssh目录
cd ~
mkdir .ssh
chmod 700 .ssh
# 赋访问权限
cp sshd_config sshd_config.bak
vim sshd_config
# 修改为PasswordAuthentication yes 保存退出
# 重启ssh服务
service sshd restart
# 复制id_rsa、id_rsa.pub、known_hosts文件到root的.ssh目录
cp id_rsa /root/.ssh/id_rsa
cp id_rsa.pub /root/.ssh/id_rsa.pub
cp known_hosts /root/.ssh/known_hosts
chmod 600 id_rsa
# 创建临时目录测试
cd ~
mkdir tmp
cd tmp
git clone -b main git@github.com:username/imagename.git ./imagename
# 测试成功后,删除.ssh文件下的目录
cd ~/.ssh
rm -rf *
4.docker配置
Dockerfile文件:
bash
# 安装ssh服务
RUN apt-get update && apt-get install -y --no-install-recommends openssh-server
# 复制所需文件到指定目录
COPY id_rsa /root/.ssh/id_rsa
COPY id_rsa.pub /root/.ssh/id_rsa.pub
COPY known_hosts /root/.ssh/known_hosts
RUN chmod 600 /root/.ssh/id_rsa \
&& chmod 644 /root/.ssh/id_rsa.pub
COPY setup_repo.sh /root/setup_repo.sh
RUN chmod +x /root/setup_repo.sh && \
/bin/bash /root/setup_repo.sh
克隆脚本setup_repo.sh:
bash
#!/bin/bash
set -e
git clone -b main git@github.com:username/imagename.git /hostpath/imagename
cd /hostpath/imagename
# 通过commit哈希指定版本
git checkout 1da7e69de3bcc18c8a965f1cd480aa5394a94b45
cd /
5.加载镜像
将Dockerfile文件,setup_repo.sh,id_rsa、id_rsa.pub、known_hosts和其他文件放到同一个目录,执行如下:
bash
# 构建imagename镜像
docker build . --network=host -t imagename
# 启动imagename镜像
docker run -it --network=host -v ./filename:/hostpath/filename imagename
6.结语
最重要的是设置私钥的600权限,否则可能会出问题。