很多镜像都在国外。比如 gcr 。国内下载很慢,需要加速。
Go to file
Shiming Zhang 08bef0976c
Fix target sync (#395)
2023-10-12 17:23:36 +08:00
.github Fix target sync (#395) 2023-10-12 17:23:36 +08:00
hack Update target sync (#391) 2023-10-12 17:11:17 +08:00
LICENSE add apache 2.0 license 2023-02-20 10:53:46 +08:00
README.md Update README.md (#389) 2023-10-11 15:56:49 +08:00
domain.txt add zalan.do for PG operator (#276) 2022-11-23 13:19:07 +08:00
exclude.txt Update exclude.txt (#266) 2022-11-09 07:42:03 +00:00
mirror.txt add ghcr.io/openinsight-proj/tailing-sidecar (#388) 2023-10-11 07:37:35 +00:00

README.md

public-image-mirror

Sync

Sync: 是 tag 的同步率 只要 tag 存在就是同步的

背景

很多镜像都在国外。比如 gcr 。国内下载很慢,需要加速。

目标

  • 一个简洁有效的方法能够加速这些包。简洁的名称映射
  • 易于添加,添加新的包,不需要去修改代码。
  • 稳定可靠,更新实时。每天检查同步情况。

快速开始

docker run -d -P m.daocloud.io/docker.io/library/nginx

使用方法

增加前缀 (推荐方式)。比如:

k8s.gcr.io/coredns/coredns => m.daocloud.io/k8s.gcr.io/coredns/coredns

或者 支持的镜像仓库 的 前缀替换 就可以使用。比如:

k8s.gcr.io/coredns/coredns => k8s-gcr.m.daocloud.io/coredns/coredns

单次单镜像同步 (强烈推荐)

您可以根据 镜像同步 Issue 模板 创建一个 Issue, 将会有机器人帮您优先主动同步指定的镜像

原先已经在下的镜像还是会继续走原来的, 需要重启 docker 再重新拉取才能走已经同步好的缓存过, 所以推荐先单次同步再尝试拉取

懒加载

支持懒加载, 就算不在同步列表中也能 直接拉取, 初次拉取会比已经同步过的慢一些, 并且每 7 天会清理一次缓存.

如果只是临时使用的就不需要往同步列表里加了, 可以尝试单次单镜像同步

如果您看到下没有进度这是由于带宽有限只要有几人在下较大的文件就会阻塞后续的下载, 可以尝试单次单镜像同步

定期同步列表 (不推荐)

mirror.txt

如果想要新增, 提 PR 修改即可。例如 PR#1 并请在 PR 提交前排序: ./hack/fmt.sh mirror.txt

对应 Registry 的映射

domain.txt

用于 github action 从源 registry 提前同步到 m.daocloud.io 下

如果想要新增, 提 PR 修改即可。例如 PR#28, 并请在 PR 提交前排序:./hack/fmt.sh domain.txt

支持前缀替换的 Registry

前缀替换的 Registry 的规则

如有新增, 提 PR 修改下面的表格, 合并后由人工配置

源站 替换为
cr.l5d.io l5d.m.daocloud.io
docker.elastic.co elastic.m.daocloud.io
docker.io docker.m.daocloud.io
gcr.io gcr.m.daocloud.io
ghcr.io ghcr.m.daocloud.io
k8s.gcr.io k8s-gcr.m.daocloud.io
registry.k8s.io k8s.m.daocloud.io
mcr.microsoft.com mcr.m.daocloud.io
nvcr.io nvcr.m.daocloud.io
quay.io quay.m.daocloud.io
registry.jujucharms.com jujucharms.m.daocloud.io
rocks.canonical.com rocks-canonical.m.daocloud.io

最佳实践

  • 通过 加速 安装 kubeadm
kubeadm config images pull --image-repository k8s-gcr.m.daocloud.io
  • 通过 加速 安装 kind
kind create cluster --name kind --image docker.m.daocloud.io/kindest/node:v1.22.1
  • 通过 加速 部署 应用(这里以 Ingress 为例)
wget -O image-filter.sh https://github.com/DaoCloud/public-image-mirror/raw/main/hack/image-filter.sh && chmod +x image-filter.sh

wget -O deploy.yaml https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.1.0/deploy/static/provider/baremetal/deploy.yaml

cat ./deploy.yaml | ./image-filter.sh | kubectl apply -f -
  • Docker 加速

添加到 /etc/docker/daemon.json

  "registry-mirrors": [
    "https://docker.m.daocloud.io"
  ]

[友情链接]加速三剑客

贡献者

Made with contrib.rocks.