使用harbor代理缓存docker hub

场景说明

当我们的 Docker-Harbor 搭建在内网的时候,我们需要同步外网的的镜像资源,以供我们内网开发人员下载使用。 这个时候我们就可以使用 Docker-Harbor 的镜像代理缓存功能。

harbor v2.1 新增了代理缓存的功能,类似nexus可以使用harbor代理并缓存来自公共或私有镜像仓库的图像。并且从harbor v2.1.1开始,代理和缓存功能已更新,以与docker hub 的速率限制保持一致

我们可以使用代理缓存功能让一些访问受限环境能够访问互联网上的镜像,并且如果没有某个镜像,此时客户端第一次发起pull image 请求会从指定的代理仓库下载并缓存到harbor的仓库里,下次别的客户端再需要pull 这个镜像就无需从公网再去下载该镜像了,从而避免占用过多带宽或被docker hub 速率限制。

操作步骤

  1. 创建DockerHub代理仓库

  2. 创建DockerHub缓存代理项目

  3. 使用DockerHub的缓存代理 要开始使用代理缓存,可以通过将docker pull命令或pod 清单使用<harbor_servername>/<proxy_project_name>/作为前缀添加到image标签,以引用代理缓存项目。例如:

    makefile 复制代码
    [root@master-01 harbor]# docker login 10.0.0.38:8004
    
    [root@master-01 harbor]# docker pull 10.0.0.38:8004/dockerhub/mysql:latest
    
    latest: Pulling from dockerhub/mysql:latest
    0e03bdcc26d7: Pull complete 
    Digest: sha256:8c5aeeb6a5f3ba4883347d3747a7249f491766ca1caa47e5da5dfcf6b9b717c0
    Status: Downloaded newer image for dockerhub/mysql:latest
    ......
  4. 我们可以看到本地仓库和Harbor的dockerhub仓库都有mysql:latest镜像了,缓存代理成功

相关推荐
不能放弃治疗1 小时前
单 Agent 实现模式
后端
IT_陈寒3 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
fliter4 小时前
最后一块拼图:用 bitvec 构造 IPv4 包,真正做出自己的 Ping
后端
fliter5 小时前
用 Rust 解析并生成 ICMP 包:checksum、nom 与 cookie-factory
后端
蝎子莱莱爱打怪5 小时前
XZLL-IM干货系列 03|消息 ID 设计:一个 UUID 搞不定的事,我用两个 ID 解决了
后端·面试·开源
fliter5 小时前
从 panic 到 Result:用 Rust 重新整理一个 ping 项目的错误处理
后端
森蓝情丶6 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
JensCS猿6 小时前
从 Spring Boot 回看 SSM 框架:手动挡与自动挡的驾驶哲学
后端
爱勇宝6 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员
科米米6 小时前
嵌入式日志模块
后端