Docker 安装与配置 Docker Registry 指南

2024-08-22 13:36

本文主要是介绍Docker 安装与配置 Docker Registry 指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、安装 Docker
  1. 解压docker.tar文件

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# tar xf docker.tar
    

    解压后检查当前目录,发现解压出一个名为 docker_install 的目录。

  2. 进入解压出的目录并查看内容

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# cd docker_install/
    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw/docker_install# ls
    docker-20.10.24-aarch64.tgz  docker-20.10.24-nvidia-x86_64.tgz  install.sh  README.md  uninstall.sh  upgrade.sh  VERSION
    

    解压出的目录包含多个文件,其中 install.sh 脚本用于安装 Docker。

  3. 执行安装脚本并指定安装路径和注册表地址

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw/docker_install# bash install.sh /data/docker 127.0.0.1:5000
    

    安装完成后,Docker 服务处于 inactive (dead) 状态。

  4. 创建目录并检查 Docker 镜像

    root@iZbp1h35mcqj4eppj2bo1rZ:/data# mkdir images
    root@iZbp1h35mcqj4eppj2bo1rZ:/data# docker images
    

    初始状态下没有任何镜像。

  5. 加载registry.tar镜像文件

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# docker load < registry.tar
    

    加载成功后,镜像 ID 为 2d4f4b5309b1

  6. 给镜像打标签并成功

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/images# docker tag 2d4f4b5309b1 registry:latest
    
  7. 检查镜像是否打标签成功

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/images# docker images
    REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
    registry     latest    2d4f4b5309b1   4 years ago   26.2MB
    

总结:

  • 成功解压并安装了 Docker。
  • 加载了 registry.tar 镜像。
  • 成功为镜像打上了 registry:latest 标签。
  • 需要注意的是,安装完成后 Docker 服务未启动,可能需要手动启动 Docker 服务。

二、准备 Docker Registry 配置文件
  1. 创建并编辑 config.yml 文件

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/images# vim config.yml
    

    config.yml 文件中添加以下内容:

    version: 0.1
    log:fields:service: registry
    storage:delete:enabled: truecache:blobdescriptor: inmemoryfilesystem:rootdirectory: /var/lib/registry
    http:addr: :5000headers:X-Content-Type-Options: [nosniff]
    health:storagedriver:enabled: trueinterval: 10sthreshold: 3
    

    配置文件说明:

    • version:配置文件版本。
    • log.fields.service:日志服务名称。
    • storage.delete.enabled:启用删除镜像功能。
    • storage.cache.blobdescriptor:缓存策略。
    • storage.filesystem.rootdirectory:镜像存储目录。
    • http.addr:注册表服务监听地址。
    • http.headers.X-Content-Type-Options:HTTP 头配置。
    • health.storagedriver:存储驱动健康检查配置。

三、运行 Docker Registry 容器
  1. 运行 Docker Registry 容器

    docker run -d -e REGISTRY_STORAGE_DELETE_ENABLED="true" --name docker-registry --restart=always -p 5000:5000 -v $PWD/registry:/var/lib/registry -v $PWD/config.yml:/etc/docker/registry/config.yml registry
    

    该命令执行后输出一个容器 ID bb88dec8a383eb0155bd7485f4fbbb031354658a8a3d1a7761795e123259c4d9,表示容器启动成功。

    具体参数解释:

    • -d:后台运行容器。
    • -e REGISTRY_STORAGE_DELETE_ENABLED="true":设置环境变量,启用删除镜像功能。
    • --name docker-registry:为容器指定名称 docker-registry
    • --restart=always:设置容器自动重启策略。
    • -p 5000:5000:将主机的 5000 端口映射到容器的 5000 端口。
    • -v $PWD/registry:/var/lib/registry:将当前目录下的 registry 目录挂载到容器内的 /var/lib/registry 目录。
    • -v $PWD/config.yml:/etc/docker/registry/config.yml:将当前目录下的 config.yml 文件挂载到容器内的 /etc/docker/registry/config.yml 文件。
    • registry:使用的镜像名称。
  2. 查看运行中的 Docker 容器

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/images# docker ps
    CONTAINER ID   IMAGE      COMMAND                  CREATED         STATUS         PORTS                                       NAMES
    bb88dec8a383   registry   "/entrypoint.sh /etc…"   6 seconds ago   Up 5 seconds   0.0.0.0:5000->5000/tcp, :::5000->5000/tcp   docker-registry
    

    可以看到容器 docker-registry 正在运行,且端口映射正确,状态正常。

  3. 检查当前目录内容

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/images# ls
    config.yml  registry
    

    当前目录下有两个文件/目录:

    • config.yml:Docker Registry 的配置文件。
    • registry:挂载到容器内 /var/lib/registry 的目录,用于存储镜像数据。

总结:

  • 成功运行了一个 Docker Registry 容器,并通过环境变量启用了删除镜像功能。
  • 通过端口映射和卷挂载,确保主机和容器之间的配置和数据共享。
  • 容器运行状态正常,可以通过 docker ps 命令确认。

四、配置 Docker Daemon 以支持私有注册表
  1. 编辑 Docker Daemon 配置文件

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# cat /etc/docker/daemon.json
    {"exec-opts": ["native.cgroupdriver=systemd"],"max-concurrent-downloads": 10,"log-driver": "json-file","log-level": "warn","log-opts": {"max-size": "10m","max-file": "3"},"bip":"172.16.0.1/16","insecure-registries":["127.0.0.1:5000","47.251.16.255:5000"],"data-root":"/data/docker"
    }
    

    配置文件说明:

    • exec-opts:Docker 容器的执行选项。
    • max-concurrent-downloads:最大并发下载数。
    • log-driver:日志驱动类型。
    • log-level:日志级别。
    • log-opts:日志选项。
    • bip:Docker 网桥 IP 地址。
    • insecure-registries:不安全的注册表地址列表。
    • data-root:Docker 数据目录。
  2. 重启 Docker 服务

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/images# systemctl restart docker
    

五、从私有注册表拉取镜像
  1. 拉取镜像

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/images# docker pull 47.251.16.255:5000/openmmlab/lmdeploy:latest
    

    拉取成功后,输出如下信息:

    latest: Pulling from openmmlab/lmdeploy
    846c0b181fff: Pulling fs layer 
    846c0b181fff: Pull complete 
    61b1f751e984: Pull complete 
    ...
    Digest: sha256:5fd5c031bf1cf2aa23153cfd5dd2bb8c9d9ce7062454c8f81d9b09ac5677fee2
    Status: Downloaded newer image for 47.251.16.255:5000/openmmlab/lmdeploy:latest
    47.251.16.255:5000/openmmlab/lmdeploy:latest
    
  2. 检查镜像是否拉取成功

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# docker images
    REPOSITORY                              TAG       IMAGE ID       CREATED       SIZE
    47.251.16.255:5000/openmmlab/lmdeploy   latest    177c26fffb4d   3 weeks ago   20.1GB
    registry                                latest    2d4f4b5309b1   4 years ago   26.2MB
    

六、推送镜像到私有注册表
  1. 标记镜像

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# docker tag 47.251.16.255:5000/openmmlab/lmdeploy 127.0.0.1:5000/openmmlab/lmdeploy
    
  2. 推送镜像

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# docker push 127.0.0.1:5000/openmmlab/lmdeploy
    

    推送成功后,输出如下信息:

    Using default tag: latest
    The push refers to repository [127.0.0.1:5000/openmmlab/lmdeploy]
    54444fae79ec: Pushed 
    5f70bf18a086: Pushed 
    ee3dcf62fd47: Pushed 
    ...
    latest: digest: sha256:5fd5c031bf1cf2aa23153cfd5dd2bb8c9d9ce7062454c8f81d9b09ac5677fee2 size: 6421
    
  3. 检查推送结果

    root@iZbp1h35mcqj4eppj2bo1rZ:/data/dw# docker images
    REPOSITORY                              TAG       IMAGE ID       CREATED       SIZE
    127.0.0.1:5000/openmmlab/lmdeploy       latest    177c26fffb4d   3 weeks ago   20.1GB
    47.251.16.255:5000/openmmlab/lmdeploy   latest    177c26fffb4d   3 weeks ago   20.1GB
    registry                                latest    2d4f4b5309b1   4 years ago   26.2MB
    

总结:

  • 成功标记并推送镜像到本地私有注册表。
  • 确保镜像在私有注册表中可用。

这篇关于Docker 安装与配置 Docker Registry 指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1096418

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了