docker搭建镜像仓库并设置账密登录

前言

在工作过程中,有时候会碰到需要把docker镜像放到另外一台机器上运行,提交到公网的docker hub太慢,如果每次导出文件传输再导入又太麻烦,还不方便进行版本控制、自动部署等操作。于是docker官方提供了一套简单的实现方案,就是Registry镜像


  1. 首先拉取镜像,执行一下命令:
powershell 复制代码
 docker pull registry:2.6.2

注:这里选用的镜像仓库版本是2.6.2,最新版删除了/usr/bin/htpasswd文件,导致创建账密找不到可执行文件

  1. 创建保存账号密码的文件
powershell 复制代码
mkdir -p  /mydata/registry/auth
docker run  --entrypoint htpasswd registry:2.6.2 -Bbn  admin 123456 > /mydata/registry/auth/htpasswd
  1. 启动容器,为了让数据持久化避免丢失,映射到宿主机
powershell 复制代码
docker run -d -p 5000:5000 --restart=always --name registry \
    -v /mydata/registry:/var/lib/registry \
    -v /mydata/registry/auth:/auth \
    -e "REGISTRY_AUTH=htpasswd" \
    -e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \
    -e  REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd \
    registry:2.6.2
  1. 配置连接私有仓库
    每台机器 docker 私有仓库配置vi /etc/docker/daemon.json写入以下内容:
bash 复制代码
{
    "insecure-registries": [
        "ip:5000"
    ]
}

然后重启docker

powershell 复制代码
systemctl daemon-reload
systemctl restart docker
  1. 现在登录私有仓库
powershell 复制代码
docker login -u username -p password ip:5000
  1. 查看私有仓库:
powershell 复制代码
curl -XGET 127.0.0.1:5000/v2/_catalog
  1. 查看镜像版本列表
powershell 复制代码
curl -XGET 127.0.0.1:5000/v2/image_name/tags/list
  1. push镜像到私有仓库
powershell 复制代码
docker tag myapp ip:5000/myapp:tag
docker push ip:5000/myapp:tag
相关推荐
鹤落晴春37 分钟前
【K8s】Pod调度、configMaps
云原生·容器·kubernetes
极客先躯2 小时前
高级java每日一道面试题-2026年02月02日-实战篇[Docker]-如何实现容器的持久化存储?
docker·容器·面试宝典·持久化·存储·韵味·java高级面试题
云计算磊哥@2 小时前
运维开发宝典026-MySQL02数据库表操作
运维·数据库·运维开发
天天进步20153 小时前
Tunnelto 源码解析 #9:控制服务器设计:Warp、WebSocket、Ping/Pong 与连接保活
运维·服务器·websocket
My is 李豆3 小时前
CentOS 7 安装 Docker 完整教程(含 docker-compose 插件)
docker·eureka·centos
极客先躯3 小时前
高级java每日一道面试题-2026年02月01日-实战篇[Docker]-Docker Volume 的生命周期管理是怎样的?
java·运维·docker·容器·持久化·架构图·容器卷
Java面试题总结4 小时前
Linux-Ubantu-贴士-apt的地盘
linux·运维·服务器
志栋智能4 小时前
超自动化巡检:提升MTTR,缩短业务影响时间
运维·自动化
kong@react4 小时前
Rocky Linux 10.2 全面解析:企业级 CentOS 替代方案及保姆级docker安装
java·linux·运维·docker
睡不醒男孩0308235 小时前
第八篇:如何构建一站式 PostgreSQL 性能优化与智能管控平台?从盲目排查到 CLup 自动化运维演进
运维·postgresql·性能优化