当前位置: 首页 > news >正文

【Docker】私有Docker仓库的搭建

一、准备工作

确保您的系统已安装Docker。如果没有安装,请参考Docker官方文档进行安装。
准备一个用于存储仓库数据的目录,例如/registry_data/。

二、拉取官方registry镜像

首先,我们需要从Docker Hub拉取官方的registry镜像。执行以下命令:

docker pull registry

三、启动私有Docker仓库

接下来,我们使用以下命令启动私有仓库:

docker run -d -p 5000:5000 -v /registry_data/:/var/lib/registry --privileged=true registry

该命令的含义如下:
-d:后台运行容器。
-p 5000:5000:将容器的5000端口映射到宿主机的5000端口。
-v /registry_data/:/var/lib/registry:将宿主机的/registry_data/目录挂载到容器的/var/lib/registry目录,用于存储仓库数据。
--privileged=true:赋予容器扩展权限。

四、配置用户认证

为了确保私有仓库的安全性,我们可以为仓库设置密码认证。如果需要,以下是如何生成密码文件并配置用户认证的步骤:

生成密码文件

首先,使用htpasswd命令生成密码文件htpasswd:

htpasswd -Bc htpasswd <username>

输入密码后,用户信息将被存储到htpasswd文件中。

添加更多用户

如果需要添加更多用户,可以使用以下命令:

htpasswd -B htpasswd <username2>
启动带用户认证的私有仓库

运行以下命令:

docker run -d \-p 5000:5000 \-v /registry_data/:/var/lib/registry \-v /htpasswd:/auth/htpasswd \-e "REGISTRY_AUTH=htpasswd" \-e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \-e "REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd" \--privileged=true \registry

-e "REGISTRY_AUTH=htpasswd":
-REGISTRY_AUTH 环境变量用于指定容器应该使用哪种认证方式。在这个例子中,htpasswd 表示将使用基本认证(HTTP基本认证),这是通过 .htpasswd 文件实现的,该文件包含用户名和加密后的密码。

-e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm":
REGISTRY_AUTH_HTPASSWD_REALM 环境变量定义了认证时的 Realm,这通常显示在认证对话框中,告知用户他们正在登录哪个服务。在这个例子中,Realm 被设置为 “Registry Realm”。

-e "REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd":
REGISTRY_AUTH_HTPASSWD_PATH 环境变量指定了 .htpasswd 文件的路径,该文件包含用户认证信息。在这个例子中,.htpasswd 文件被挂载到容器内的 /auth/htpasswd 路径。

五、配置Docker守护进程

为了让Docker客户端能够访问私有仓库,我们需要将仓库地址添加到Docker的daemon.json文件中。执行以下命令:

{"insecure-registries": ["<your-repo-domain>:<your-repo-port>"]
}

其中,和分别替换为您的私有仓库域名和端口。
修改完成后,重载Docker:

systemctl reload docker

至此,私有Docker仓库搭建完成,您可以使用以下命令进行登录和推送镜像:
最后,我们使用以下命令启动带用户认证的私有仓库:

docker login <your-repo-domain>:<your-repo-port>
docker tag <image-name> <your-repo-domain>:<your-repo-port>/<image-name>
docker push <your-repo-domain>:<your-repo-port>/<image-name>

以上就是搭建私有Docker仓库的详细步骤,希望对您有所帮助!

http://www.lryc.cn/news/525878.html

相关文章:

  • linux 管道符、重定向与环境变量
  • Ansible fetch模块详解:轻松从远程主机抓取文件
  • wireshark工具简介
  • 51单片机——按键控制LED流水灯
  • 【opencv】第9章 直方图与匹配
  • HTML5 Web Worker 的使用与实践
  • MVCC底层原理实现
  • 基于ESP32-IDF驱动GPIO输出控制LED
  • 【优选算法】9----长度最小的子数组
  • LabVIEW太阳能照明监控系统
  • MongoDB中单对象大小超16M的存储方案
  • 三维激光扫描-用智能检测系统提升效率
  • css遇到的一些问题
  • 【langgraph】ubuntu安装:langgraph:未找到命令
  • mysql 学习2 MYSQL数据模型,mysql内部可以创建多个数据库,一个数据库中有多个表;表是真正放数据的地方,关系型数据库 。
  • 小识JVM堆内存管理的优化机制TLAB
  • ToDesk云电脑、顺网云、网易云、易腾云、极云普惠云横测对比:探寻电竞最佳拍档
  • 学习ASP.NET Core的身份认证(基于JwtBearer的身份认证10)
  • vscode环境中用仓颉语言开发时调出覆盖率的方法
  • OLED--软件I2C驱动__标准库和HAL库
  • 【设计模式-行为型】观察者模式
  • 从理论到实践:Django 业务日志配置与优化指南
  • Linux下php8安装phpredis扩展的方法
  • Flink运行时架构
  • JupyterLab 安装以及部分相关配置
  • PC端实现PDF预览(支持后端返回文件流 || 返回文件URL)
  • 大模型 / 智能体在智能运维领域的应用总结与发展趋势概述
  • uniapp 在线更新应用
  • AIGC视频生成模型:ByteDance的PixelDance模型
  • python远程获取数据库中的相关数据并存储至json文件