Docker-compose搭建Docker Hub镜像仓库整合SpringBootCloud

Docker-compose搭建Docker Hub镜像仓库

准备工作

确保已安装Docker和Docker-compose。建议使用Linux环境,并分配至少2GB内存。

创建配置文件

新建目录docker-registry,在该目录下创建docker-compose.yml文件,内容如下:

yaml 复制代码
version: '3'

services:
  registry:
    image: registry:2
    ports:
      - "5000:5000"
    volumes:
      - ./data:/var/lib/registry
    environment:
      REGISTRY_STORAGE_DELETE_ENABLED: "true"

启动服务

在目录下执行命令启动服务:

bash 复制代码
docker-compose up -d

验证服务

检查服务是否正常运行:

bash 复制代码
curl http://localhost:5000/v2/_catalog

预期输出为{"repositories":[]},表示仓库为空但服务正常。

配置客户端

若需从其他主机访问,需修改Docker客户端配置(Linux系统):

  1. 编辑/etc/docker/daemon.json,添加:
json 复制代码
{
  "insecure-registries": ["your-server-ip:5000"]
}
  1. 重启Docker服务:
bash 复制代码
sudo systemctl restart docker

推送镜像示例

标记并推送本地镜像到私有仓库:

bash 复制代码
docker tag your-image your-server-ip:5000/your-image
docker push your-server-ip:5000/your-image

管理镜像

删除镜像需调用Registry API:

bash 复制代码
curl -X DELETE http://your-server-ip:5000/v2/your-image/manifests/<digest>

通过docker exec进入容器执行垃圾回收:

bash 复制代码
docker exec -it registry_container bin/registry garbage-collect /etc/docker/registry/config.yml

持久化数据

所有镜像数据会保存在./data目录,定期备份该目录即可。

HTTPS配置(可选)

如需启用HTTPS,需在docker-compose.yml中挂载证书文件:

yaml 复制代码
volumes:
  - ./certs:/certs
environment:
  REGISTRY_HTTP_TLS_CERTIFICATE: /certs/domain.crt
  REGISTRY_HTTP_TLS_KEY: /certs/domain.key

注意事项

  • 默认配置仅适合测试环境,生产环境需配置认证(如添加htpasswd)。
  • 存储路径可根据需求修改为NFS或其他持久化存储方案。
  • Registry API版本可能变化,建议查阅官方文档获取最新参数。
相关推荐
SongYuLong的博客2 小时前
Ubuntu24.04搭建GitLab服务器
运维·服务器·gitlab
guygg882 小时前
Linux服务器上安装配置GitLab
linux·运维·gitlab
RokFile2 小时前
SysInfoKeeper是一款面向 Linux/Unix 的硬件变动检测 CLI 工具
运维
地球没有花2 小时前
gitlab cicd 模块解释
运维·ci/cd·gitlab
列星随旋2 小时前
初识RabbitMQ
分布式·rabbitmq·ruby
zl9798993 小时前
RabbitMQ-交换机
分布式·rabbitmq
Serverless社区3 小时前
【本不该故障系列】从 runC 到 runD:SAE 如何化解安全泄露风险
阿里云·云原生·serverless
AI大模型学徒3 小时前
Docker(五)_数据根目录空间不足的原因与解决方法
运维·docker·容器
惊涛说IT3 小时前
Dockerfile入门案例
docker