使用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镜像了,缓存代理成功

相关推荐
鱼人3 分钟前
内存泄漏:隐形杀手与防御指南
后端
武子康4 分钟前
大数据-250 离线数仓 - 电商分析 Hive 数仓 ADS 层订单分析实战:全国/大区/城市分类汇总与 Airflow 调度
大数据·后端·apache hive
小箌11 分钟前
springboot_01
java·spring boot·后端
开心就好202533 分钟前
全面解析WhatsApp Web抓包:原理、工具与安全
后端·ios
未秃头的程序猿37 分钟前
🚀 别再手写 RabbitMQ 样板代码了!这个开源 Starter 让消息队列集成只需 5 分钟
后端·rabbitmq
crossoverJie1 小时前
DeepWiki 优化实战:代码行号与确定性目录生成
后端·ai编程
salipopl1 小时前
Spring Boot 集成 MyBatis 全面讲解
spring boot·后端·mybatis
zone77391 小时前
008-01:RAG 入门-向量存储与企业级向量数据库 milvus
后端·面试·agent
Java水解1 小时前
Spring Boot 数据仓库与ETL工具集成
spring boot·后端
Cache技术分享1 小时前
355. Java IO API -去除路径中的冗余信息
前端·后端