自建docker镜像仓库

继国内dockerhub被墙,大厂镜像被禁以后,国内使用docker越来越不舒服,为了解决该困扰教大家自建镜像仓库。

香港服务器 + Docker Registry + 本地 HTTP 代理 ,实现国内机器无缝拉取 Docker Hub 镜像。全程只需要 3 步。


整体思路

  1. 香港服务器:起一个 Docker Registry 代理(registry proxy),它会自动从 Docker Hub 拉取并缓存
  2. 香港服务器:开一个 HTTP 代理(Caddy/Nginx) 给国内机器访问
  3. 国内机器:配置 daemon.json 指向香港代理

一、香港服务器操作(Docker + Registry Proxy)

1. 安装 Docker(已装可跳过)

复制代码
curl -fsSL https://get.docker.com | bash
systemctl enable --now docker

2. 启动 Docker Registry 代理(关键)

创建目录:

复制代码
mkdir -p /data/registry

启动代理 registry(直接复制运行):

复制代码
docker run -d \
  --restart=always \
  --name registry-proxy \
  -p 5000:5000 \
  -v /data/registry:/var/lib/registry \
  -e REGISTRY_PROXY_REMOTEURL=https://registry-1.docker.io \
  -e REGISTRY_STORAGE_FILESYSTEM_ROOTDIRECTORY=/var/lib/registry \
  registry:2

这就是一个 Docker Hub 中转缓存仓库

  • 国内拉取 → 香港代理 → 第一次去 Docker Hub 拉,后面直接走缓存。

二、香港服务器:开放端口

复制代码
# 防火墙开放 5000
ufw allow 5000/tcp

安全建议:生产环境建议加账号密码或限制来源 IP。


三、国内机器配置(关键)

1. 编辑 /etc/docker/daemon.json

复制代码
vim /etc/docker/daemon.json

写入(把 你的香港IP 替换掉):

复制代码
{
  "registry-mirrors": [
    "http://你的香港IP:5000"
  ]
}

2. 重启 Docker

复制代码
systemctl daemon-reload
systemctl restart docker

四、测试是否成功

国内机器直接执行:

复制代码
docker pull nginx

会自动从 香港服务器中转拉取,速度非常快。


五、进阶(可选,更安全)

如果你希望:

  • 账号密码认证
  • HTTPS
  • 域名
  • 限制国内 IP 白名单
相关推荐
“码”力全开16 分钟前
解耦异构算力:基于 Docker 与边缘计算的 AI 视频管理平台,实现 GB28181/RTSP 统一接入与源码交付深度解析
人工智能·docker·边缘计算
正经教主1 小时前
【docker基础】第六课:Web应用与数据库容器部署
网络·docker·容器
Shacoray2 小时前
K8s 中 Ingress 的 HTTPS 证书 如何生成?
容器·https·kubernetes
开发者联盟league2 小时前
使用k8s安装Jenkins
容器·kubernetes·jenkins
“码”力全开2 小时前
突破安防黑盒:基于 Docker 与边缘计算的 AI 视频管理平台,实现 GB28181/RTSP 统一接入与全源码交付二次开发架构解析
人工智能·docker·边缘计算
花间相见3 小时前
【AI工作流搭建n8n】—— Docker + PostgreSQL 生产环境部署全攻略:MCP 集成与 Skills 技能实战
人工智能·docker·postgresql
正经教主3 小时前
【docker基础】 第七课:Docker Compose 多容器实战
运维·docker·容器
正经教主3 小时前
【docker基础】Redis的docker部署
redis·docker·容器
是一个Bug3 小时前
Docker 与 Kubernetes:从“集装箱”到“远洋舰队”
docker·容器·kubernetes
java_cj3 小时前
阅读 k8s 源码的准备工作
云原生·容器·kubernetes