无法愉快拉取 gcr.io、quay.io、ghcr.io 容器镜像?手把手教你用魔法来打败魔法

公众号关注 「奇妙的 Linux 世界」

设为「星标」,每天带你玩转 Linux !

1c0d6ed25d19f694629c3302a35ee6b6.png

目前常用的 Docker Registry 公开服务有:

  • docker.io :Docker Hub 官方镜像仓库,也是 Docker 默认的仓库

  • gcr.iok8s.gcr.io :谷歌镜像仓库

  • quay.io :Red Hat 镜像仓库

  • ghcr.io :GitHub 镜像仓库

当使用 docker pull 仓库地址/用户名/仓库名:标签 时,会前往对应的仓库地址拉取镜像,标签无声明时默认为 latest, 仓库地址无声明时默认为 docker.io 。

d0e39a6074745dc3e88b614596aa8171.png

众所周知的原因,在国内访问这些服务异常的慢,甚至 gcr.io 和 quay.io 根本无法访问。

26f440f0b3e003b183e254766641188a.png

解决方案:镜像加速器

针对 Docker Hub ,Docker 官方和国内各大云服务商均提供了 Docker 镜像加速服务。

你只需要简单配置一下(以 Linux 为例):

sudo mkdir -p /etc/docker

sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["镜像加速器"]
}
EOF

sudo systemctl daemon-reload
sudo service docker restart

便可以通过访问国内镜像加速器来加速 Docker Hub 的镜像下载。

dc81a651d0e96cd78d4a9446b925f6ce.png

不过这种办法也只能针对 docker.io ,其它的仓库地址并没有真正实际可用的加速器(至少我目前没找到)。

解决方案:用魔法打败魔法

既然无法治本,那治治标还是可以的吧。

若我们使用一台魔法机器从 gcr.io 或 quay.io 等仓库先把我们无法下载的镜像拉取下来,然后重新上传到 docker.io ,是不是就可以使用 Docker Hub 的镜像加速器来下载了。

252b70e155e4d7149007d4d1f99452ed.png

镜像仓库迁移的功能,我这里采用了 Go Docker SDK ,整体实现也比较简单。

e2ce6806c4b1145b4489692071b2b5e7.png

以需要转换的 gcr.io/google-samples/microservices-demo/emailservice:v0.3.5 为例,使用方式:

2bb7f6d00533fb8895ea94d411c7f71c.png

功能实现了,剩下的就是找台带有魔法的机器了。

GitHub Actions 就是个好选择,我们可以利用提交 issues 来触发镜像仓库迁移的功能。

workflow 的实现如下:

031c601b9882ed8bc0510b6c97944a45.png

实际的使用效果:

c9d746a2fd35eb16891a58fb4bd34c16.png

只要执行最终输出的命令,就可以飞快的使用 Docker Hub 的加速器下载 gcr.io 或 quay.io 等镜像了。

最后

本篇的实现已放在 GitHub :https://github.com/togettoyou/hub-mirror

本文转载自:「SuperGopher」,原文:https://url.hi-linux.com/qKdwq,版权归原作者所有。欢迎投稿,投稿邮箱: editor@hi-linux.com。

f61d30d3faaea08696506ac18a13c25d.gif

最近,我们建立了一个技术交流微信群。目前群里已加入了不少行业内的大神,有兴趣的同学可以加入和我们一起交流技术,在 「奇妙的 Linux 世界」 公众号直接回复 「加群」 邀请你入群。

f614b3c2acfc74705276facc01decf47.png

你可能还喜欢

点击下方图片即可阅读

ec5e9ae62d8e048516929604e65180b1.png

KubeGems: 一款超强大面向云原生的通用开源 PaaS 管理平台,支持 Argo CD、Istio 等 30+ 开源服务

ca2156364d0a49bc1687c871cc09c5d3.png
点击上方图片,『美团|饿了么』外卖红包天天免费领

c97fa352731fb3357aa03fe25a489186.png

更多有趣的互联网新鲜事,关注「奇妙的互联网」视频号全了解!

在 CentOS 上使用 Podman 启动 Minikube 并遇到 "Error: initializing source docker://gcr.io/k8s-minikube/kicbase:v0.0.39: pinging container registry gcr.io: Get "https://gcr.io/v2/": dial tcp 74.125.23.82:443: i/o timeout" 错误,说明 Podman 无法从 `gcr.io` 上拉取镜像。 这个错误通常是由于网络连接问题导致的。你可以尝试以下解决方法: 1. 检查网络连接: 确保你的网络连接正常,并且可以访问互联网。尝试使用浏览器或其他网络工具访问 `https://gcr.io/v2/`,看看是否可以成功连接。 2. 检查防火墙设置: 检查你的系统防火墙或网络防火墙设置,确保允许与 `gcr.io` 的通信。如果有防火墙规则限制对特定 IP 或端口的访问,你可能需要相应地进行配置。 3. 使用代理: 如果你的网络使用代理,请确保 Podman 可以通过代理连接到 `gcr.io`。你可以设置相应的代理环境变量,以便 Podman 使用正确的代理配置。 ``` export HTTP_PROXY=http://proxy.example.com:port export HTTPS_PROXY=http://proxy.example.com:port ``` 将 `proxy.example.com` 和 `port` 替换为你的代理服务器和端口。 4. 更换镜像源: 如果你无法访问 `gcr.io`,可以尝试使用其他镜像源。你可以通过修改 Podman 的配置文件来指定其他镜像源,例如 Docker Hub 或其他私有镜像仓库。 首先,打开 Podman 的配置文件 `/etc/containers/registries.conf`: ``` sudo vi /etc/containers/registries.conf ``` 然后,将 `gcr.io` 替换为其他镜像源的地址。例如,将其替换为 Docker Hub 的地址: ``` [registries.search] registries = ['docker.io'] ``` 保存并关闭文件。然后重新启动 Podman 并尝试启动 Minikube。 如果问题仍然存在,请确保你的系统满足 Minikube 和 Podman 的最低要求,并参考 Minikube 和 Podman 的官方文档或社区支持寻求进一步的帮助。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值