docker 搭建私有仓库并发布私有镜像

简介: docker 搭建私有仓库并发布私有镜像

本文为博主原创,转载请注明出处:  

1.自建私有docker仓库

  自建一个Docker仓库,可以使用Docker官方提供的开源项目Docker Registry。以下是一些基本步骤:

  1. 安装Docker Registry:
  • 在服务器上安装Docker引擎。
  • 使用以下命令拉取Docker Registry镜像:docker pull registry:latest
  1. 创建Docker Registry容器:
  • 运行以下命令创建一个Docker Registry容器:
docker run -d -p 5000:5000 --restart=always --name registry registry:latest
  1. 配置Docker Registry:
  • 编辑/etc/docker/daemon.json文件,添加以下内容,以允许Docker客户端连接到自建的
• Docker Registry:
{
  "insecure-registries": ["your-registry-domain:5000"]
}
  • 重启Docker守护进程:sudo systemctl restart docker
  1. 验证Docker Registry是否正常运行:
  • 在本地或其他机器上运行以下命令,确保能够连接到自建的Docker Registry:
docker login your-registry-domain:5000

  5.使用自建的Docker Registry:

  • 构建自己的Docker镜像,并为其添加your-registry-domain:5000作为镜像仓库的前缀,例如:
docker build -t your-registry-domain:5000/my-image:tag .

  推送镜像到自建的Docker Registry:

docker push your-registry-domain:5000/my-image:tag

  现在,已经成功自建了一个Docker仓库。其他机器可以使用相同的域名和端口连接到该仓库,并拉取或推送镜像。请注意,这里只提供了一个简单的自建Docker仓库的示例,实际上还可以进行更高级的配置和安全性设置。

  6.推送和拉取镜像:

  • 使用 docker push 命令将本地镜像推送到私有仓库。
  • 例如:docker push my-registry:5000/my-image:latest 将本地镜像推送到私有仓库中。
  • 使用 docker pull 命令从私有仓库拉取镜像。
  • 例如:docker pull my-registry:5000/my-image:latest 将从私有仓库中拉取指定镜像。

2.公有仓库和私有仓库得使用和区分

  在使用 Docker 时,可以通过在镜像名称中指定仓库地址来区分使用公有仓库还是私有仓库。

  1. 使用公有仓库:
  • 默认情况下,当未指定仓库地址时,Docker 会将镜像看作是从 Docker Hub(公有仓库)拉取的。
  • 使用 docker pull 命令时,只需提供镜像名称即可,例如 docker pull ubuntu:latest
  1. 使用私有仓库:
  • 如果您要使用私有仓库中的镜像,需要在镜像名称中包含私有仓库的地址。
  • 格式为 <registry-address>/<repository-name>:<tag>,其中 <registry-address> 是私有仓库的地址,可以是 IP 地址或域名。
  • 使用 docker pull 命令时,指定私有仓库中的镜像名称,例如 docker pull my-registry:5000/my-image:latest

  另外,在推送镜像到私有仓库时,也需要指定仓库地址。使用 docker tag 命令将本地镜像标记为要推送到的私有仓库,并在推送时指定镜像的仓库地址。示例:

# 标记本地镜像

docker tag my-local-image:latest my-registry:5000/my-image:latest


# 推送镜像到私有仓库

docker push my-registry:5000/my-image:latest

  通过指定镜像名称中的仓库地址,可以明确使用公有仓库还是私有仓库中的镜像。根据需要,切换到相应的仓库进行操作。

3.本地发布java服务镜像

  1. 创建 Dockerfile:
  • 在 Java 服务项目的根目录中创建一个名为 Dockerfile 的文本文件。
  • 使用任何文本编辑器打开 Dockerfile 文件。
  1. 编写 Dockerfile:
  • Dockerfile 中编写构建镜像所需的指令。
  • 您需要选择适当的基础镜像、复制文件、安装 Java 运行时环境等步骤。

  示例:

# 选择基础镜像(例如 OpenJDK)
FROM openjdk:11-jre-slim
# 将服务 jar 包和配置文件复制到镜像
COPY test.jar /app/
COPY config.properties /app/
# 设置工作目录
WORKDIR /app
# 运行 Java 服务
CMD ["java", "-jar", "test.jar"]

  3.准备服务 JAR 包和配置文件:

  • 将 Java 服务的 JAR 包(例如 test.jar)和配置文件(例如 config.properties)放置在与 Dockerfile 相同的目录下。

  4.构建镜像:

  • 打开终端或命令提示符,并定位到包含 Dockerfile 的项目目录
  • 使用 docker build 命令构建镜像
  • 例如:docker build -t my-java-service:1.0 .
  • 注意:my-java-service 是镜像的名称,1.0 是标签(版本号),. 表示使用当前目录作为构建上下文

  5.查看构建的镜像:

  • 运行 docker images 命令查看本地构建的镜像列表。
  • 您应该能够在列表中看到刚刚构建的镜像。

  6.推送镜像到私有仓库:

  • 使用 docker push 命令将本地构建的镜像推送到私有 Docker 仓库。
  • 例如:docker push <registry-address>/<repository-name>:<tag>
  • 示例:docker push my-registry:5000/my-image:latest 将推送名为 "my-image" 的最新版本镜像到私有仓库中。

  7.查看私有仓库中的镜像:

  • 登录到私有仓库的管理界面或使用相应的命令,例如 docker search 或者私有仓库专用的命令,查看镜像是否成功推送到私有仓库中。

  通过执行以上步骤,您将能够将本地的 Java 服务和配置文件打包到一个 Docker 镜像中。确保 Dockerfile、JAR 包和配置文件在同一目录下,并根据需要调整 Dockerfile 中的指令和配置,以适应您的项目需求。

 

标签: docker

目录
相关文章
|
16天前
|
应用服务中间件 Linux nginx
Docker镜像-手动制作yum版nginx镜像
这篇文章介绍了如何手动制作一个基于CentOS 7.6的Docker镜像,其中包括下载指定版本的CentOS镜像,创建容器,配置阿里云软件源,安装并配置nginx,自定义nginx日志格式和web页面,最后提交镜像并基于该镜像启动新容器的详细步骤。
75 21
Docker镜像-手动制作yum版nginx镜像
|
16天前
|
应用服务中间件 nginx Docker
Docker镜像-基于DockerFile制作编译版nginx镜像
这篇文章介绍了如何基于Dockerfile制作一个编译版的nginx镜像,并提供了详细的步骤和命令。
92 17
Docker镜像-基于DockerFile制作编译版nginx镜像
|
16天前
|
Docker 容器
Docker自建仓库之Harbor高可用部署实战篇
关于如何部署Harbor高可用性的实战教程,涵盖了从单机部署到镜像仓库同步的详细步骤。
54 15
Docker自建仓库之Harbor高可用部署实战篇
|
16天前
|
应用服务中间件 Linux nginx
Docker镜像管理篇
关于Docker镜像管理的教程,涵盖了Docker镜像的基本概念、管理命令以及如何制作Docker镜像等内容。
75 7
Docker镜像管理篇
|
16天前
|
应用服务中间件 Linux nginx
Docker镜像-基于DockerFile制作yum版nginx镜像
本文介绍了如何使用Dockerfile制作一个基于CentOS 7.6.1810的yum版nginx镜像,并提供了详细的步骤和命令。
57 20
|
16天前
|
存储 测试技术 数据安全/隐私保护
Docker自建仓库之Harbor部署实战
关于如何部署和使用Harbor作为Docker企业级私有镜像仓库的详细教程。
35 12
|
16天前
|
Docker 容器
Docker Hub镜像公共仓库使用
这篇文章介绍了如何使用Docker Hub公共仓库进行镜像的创建、上传、下载和管理。
263 8
|
16天前
|
运维 数据安全/隐私保护 Docker
Docker自建仓库之Docker Registry部署实战
关于如何使用Docker Registry镜像搭建本地私有Docker仓库的实战教程,包括了下载镜像、创建授权目录和用户名密码、启动Registry容器、验证端口和容器、测试登录仓库、上传和下载镜像的详细步骤。
58 5
|
15天前
|
应用服务中间件 nginx 数据安全/隐私保护
使用Harbor搭建Docker私有仓库
Harbor是一款开源的企业级Docker仓库管理工具,分为私有与公有仓库两种类型,其中私有仓库被广泛应用于运维场景。Harbor提供图形化界面,便于直观操作,并且其核心组件均由容器构建而成,因此安装时需预先配置Docker及docker-compose。Harbor支持基于项目的用户与仓库管理,实现细粒度的权限控制;具备镜像复制、日志收集等功能,并可通过UI直接管理镜像,支持审计追踪。部署Harbor涉及配置文件调整、登录认证等步骤,并可通过客户端进行镜像的上传、拉取等操作。系统内置多种角色,包括受限访客、访客、开发者、维护人员及管理员,以满足不同场景下的使用需求。
69 0
|
22天前
|
存储 安全 Ubuntu
Docker 镜像与 Docker 容器的区别
【8月更文挑战第27天】
61 5