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

docker,搭建,私有,仓库,发布,镜像 · 浏览次数 : 351

小编点评

**自建 Docker 仓库指南** **1. 安装 Docker Engine** 使用以下命令安装 Docker Engine: ```bash sudo apt install docker ``` **2. 创建 Docker Registry** 使用以下命令创建一个 Docker Registry: ```bash docker run -d -p 5000:5000 --restart=always --name registry registry:latest ``` **3. 配置 Docker Registry** 打开 `/etc/docker/daemon.json` 文件,添加以下内容以允许 Docker 客户端连接到自建的 Docker Registry: ```json { "insecure-registries": [ "your-registry-domain:5000" ] } ``` **4. 使用自建的 Docker Registry** 构建自己的 Docker 镜像,并为其添加 `your-registry-domain:5000` 作为镜像仓库的前缀,例如: ```bash docker build -t your-registry-domain:5000/my-image:tag . ``` **5. 推送镜像到私有仓库** 使用 `docker push` 命令将本地镜像推送到私有仓库: ```bash docker push your-registry-domain:5000/my-image:tag ``` **6. 推送和拉取镜像** 可以使用以下命令从私有仓库拉取镜像: ```bash docker pull your-registry-domain:5000/my-image:tag ``` **7. 本地发布 Java 服务镜像** 创建一个名为 `Dockerfile` 的文本文件,包含 Dockerfile 中的指令,例如: ``` FROM openjdk:11-jre-slim COPY test.jar /app/COPY config.properties /app/# RUN [\"java\", "-jar\", \"test.jar\"] ``` 构建镜像: ```bash docker build -t my-java-service:1.0 . ``` **8. 查看构建的镜像** 使用 `docker images` 命令查看本地构建的镜像列表。 **9. 推送镜像到私有仓库** 使用 `docker push` 命令将本地构建的镜像推送到私有仓库: ```bash docker push my-registry:5000/my-image:latest ``` **10. 查看私有仓库中的镜像** 登录到私有仓库的管理界面或使用相应的命令,例如 `docker search` 或 `docker images`,查看镜像是否成功推送到私有仓库中。

正文

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

1.自建私有docker仓库

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

  1. 安装Docker Registry:

    • 在服务器上安装Docker引擎。

    • 使用以下命令拉取Docker Registry镜像:docker pull registry:latest

  2. 创建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
  2. 使用私有仓库:

    • 如果您要使用私有仓库中的镜像,需要在镜像名称中包含私有仓库的地址。
    • 格式为 <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 文件。
  2. 编写 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 搭建私有仓库并发布私有镜像相似的内容:

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

本文为博主原创,转载请注明出处: 1.自建私有docker仓库 自建一个Docker仓库,可以使用Docker官方提供的开源项目Docker Registry。以下是一些基本步骤: 安装Docker Registry: 在服务器上安装Docker引擎。 使用以下命令拉取Docker Registry

手把手教你搭建Docker私有仓库Harbor

1、什么是Docker私有仓库 Docker私有仓库是用于存储和管理Docker镜像的私有存储库。Docker默认会有一个公共的仓库Docker Hub,而与Docker Hub不同,私有仓库是受限访问的,只有授权用户才能够上传、下载和管理其中的镜像。这种私有仓库可以部署在本地云环境中,用于组织内部

配置pod拉取harbor容器镜像仓库私有镜像:secret保存账号密码

配置pod拉取harbor容器镜像仓库私有镜像:secret保存账号密码,Docker-Registry类型的Secret简介,镜像仓库简介,搭建Harbor容器镜像仓库,安装Harbor,创建项目,推送镜像到harbor镜像仓库,使用secret保存harbor账号密码拉取私有仓库的镜像

影片自由,丝滑流畅,Docker容器基于WebDav协议通过Alist挂载(百度网盘/阿里云盘)Python3.10接入

使用过NAS(Network Attached Storage)的朋友都知道,它可以通过局域网将本地硬盘转换为局域网内的“网盘”,简单理解就是搭建自己的“私有云”,但是硬件和网络成本都太高了,有点可望而不可及的意思。Alist开源库则可以满足我们,它能将公共网盘反过来变成一种联网的本地硬盘,使用We

Asp-Net-Core开发笔记:FrameworkDependent搭配docker部署

## 前言 之前我写过一篇使用 docker 部署 AspNetCore 应用的文章,这种方式搭配 CICD 非常方便, build 之后 push 到私有的 dockerhub ,在生产服务器上 pull 下来镜像就可以直接运行了。 然而,有时需要一种更传统的部署方式,比如在本地打包可执行文件之后

[转帖]docker 搭建 redis 伪分布式集群

https://www.jianshu.com/p/453a2d70a5de 建议阅读方式 可前往语雀阅读,体验更好:docker 搭建 redis 伪分布式集群 背景介绍 该实验主要来源于《Docker 容器与容器云 第2版》一书的 2.3 节:“搭建你的第一个 Docker 应用栈”中的一小步,

使用docker搭建ELK分布式日志同步方案

ELK作为业界最常用日志同步方案,我们今天尝试一下使用docker快速搭建一套ELK方案。ELK使用国内加速源拉取的镜像比较旧,有条件的朋友可以拉取官网的源。elasticsearch作为日志储存库(数据库),kibana的作用通过elasticsearch的API接口调取其中数据作可视化分析,lo

在Docker中搭建rabbit MQ集群 (Mac + OrbStack)

我以为用docker搭建一个rabbitMq集群会非常简单,但是结果却出乎意料,我花了差不多两个半天才搞定。这还是依赖了AI的协助,否则难度不敢想象。 我的环境是Mac上的OrbStack。用了Kimi + 文心一言 + ChatGPT + Claude,还是Kimi价值最大。 back and f

EMQX配置ssl/tls双向认证+SpringBoot项目整合MQTT_真实业务实践

一.使用docker搭建Emqx 1.拉取emqx镜像 docker pull emqx/emqx:5.7 2.运行 docker run -d --name emqx emqx/emqx:5.7 3.拷贝 docker中 etc data log 到宿主机的 /opt/emqx 下 mkdir -

connect() failed (113: No route to host) while connecting to upstream

转载请注明出处: 用docker 搭建的服务,今天重启了一个容器之后,请求这个服务的接口都变成了 502, 但通过docker 查看日志,发现没有异常,端口也都是正常,在nginx的日志中看到了这段错误信息 在nginx 的日志中看到:connect() failed (113: No route