docker私有镜像服务搭建

2023-05-16

    docker容器技术已经在部署服务上使用的非常普遍,主要是它的隔离性以及快速启动的特性,一般启动一个容器,如果镜像不存在会先去dockerhub仓库下载,然后存储在本地,后续可以继续或者反复使用这个镜像,但是一旦这个镜像被删除了,或者需要一个新的镜像的时候,我们还是需要远程下载,网速如果不给力的话,下载时间就会很漫长,为此就诞生了docker镜像私服这个服务,可以把需要的镜像提交到私服上,一般私服是局域网内部的一台服务器,当我们需要镜像的时候,下载速度会大幅提升。

    docker私服不是一个管理docker容器和镜像的服务,而是一个提供本地下载镜像的服务,就好比maven本地仓库,如果我们本地有了我们需要的依赖,会直接加载本地的依赖,只有本地没有的时候,我们才会去远程服务器仓库下载。

    docker私服的搭建很简单,我们只需要运行一个名叫registry的docker镜像并启动,就构建了一个docker私服。这里如果私服的服务器地址为192.168.56.141对应主机名为docker01,我们的docker服务器在另外一台服务器上,服务器地址为192.168.56.142,对应主机名为docker02。一般为了管理方便,我们的docker私服会单独选择一台服务器,而真正运行docker容器的机器是另一台服务器。下面给出两台服务器的信息:

docker01 -> ip: 192.168.56.141  -> docker run -d registry

docker02 -> ip:192.168.56.142  -> docker pull mongo  -> docker tag mongo:latest docker01:5000/mongo:latest -> docker push docker01:5000/mongo

    其实构建本地私服很简单,我们假设docker01是私服服务器,docker02是运行docker其他容器的服务器。docker01只负责提供本地仓库镜像下载服务,docker02或者其他客户端需要镜像的时候,直接从docker01拉取,而不是从外网拉取,这样节省镜像下载时间。

    我们本次实验的结果就是通过搭建docker私服最终感受一下从私服拉取镜像是多么快。

    这次实验我采用的虚拟机是ubuntu1804,这样,我们在开始之前,需要安装docker,具体安装,我直接采用的是sudo apt install docker.io。

    

    检查安装版本信息:

     

    直接安装完成,docker服务就开启了。

    开启docker私服,其实很简单,我们直接在docker01上运行registry镜像即可。

    # docker run -d -p 5000:5000 --name registry registry

    

    运行完成,我们就开启了一个docker私服,下面就是通过curl命令验证一下私服仓库最开始没有镜像的情况:

     

    我们需要向docker01私服上推送一些镜像,这个镜像第一次需要我们通过官方仓库拉取:

     

    通过官方拉取镜像会很慢,我们可以考虑增加镜像加速器配置:第一次是新增,后面就是修改/etc/docker/daemon.json,我这里是配置的阿里云的加速器。

{
 "registry-mirrors": ["https://lz9fye6c.mirror.aliyuncs.com"]
}

    配置完成,需要我们重启docker服务。

   # sudo systemctl daemon-reload

   # sudo systemctl restart docker

    

    拉取成功了,我们需要给这个镜像打上标签,就是tag,如下所示:

    # docker tag mongo:latest docker01:5000/mongo:latest

    接着我们需要push到docker01上。

    # docker push docker01:5000/mongo

    如果不出意外,肯定会失败的,这是因为我们使用的是http协议,而registry默认是使用的https协议:

     

    我们需要修改docker02,也就是docker私服对应客户端这边的daemon.json配置文件,增加安全选项配置:"insecure-registries":["docker01:5000"],最后完整的配置如下所示:

{
 "registry-mirrors": ["https://lz9fye6c.mirror.aliyuncs.com"],"insecure-registries":["docker01:5000"]
}

    我们再次push,就成功了。

     

     验证推送成功: 

    

     这时候docker02上有两个镜像一个是原始拉取的,再一个是我们通过tag命令打出的。而在docker01的私服仓库上有一个mongo的镜像,不过docker01上通过docker images还是只有一个registry的镜像。这里好像比较难以理解,docker01上的私服是通过docker运行的,而他私服仓库中的镜像不是docker images的镜像,所以只能通过http://docker01:5000/v2/_catalog来查看。

    我们将docker02上的所有镜像都删除,通过如下命令:

    # docker rmi mongo 

    # docker rmi docker01:5000/mongo

    这是为了演示,当我们从docker01私服上拉取镜像的时候是多么快速:

    

    拉取过来的镜像:

     

     以上就是搭建私服的过程,这是简单体验了一下,一般私服是通过https协议来推送和拉取的,所以文中会有一个默认推送失败的情况,但是也可以通过设置跳过这个限定。

    最后整理一下docker私服搭建的过程:

    1、私服搭建还是借助于docker镜像容器,镜像的名字就是registry。默认开启的端口是5000。

    2、私服搭建很简单,我们一般把私服只作为一个私服服务器,不会再当做除registry容器之外运行的docker服务器。

    3、推送镜像的时候,默认是https协议,为了绕过https,我们可以设置daemon.json配置文件中的参数insecure-registries。

    4、推送镜像的时候 ,我们使用的命令是docker push docker01:5000/mongo,就将mongo镜像推送到了私服仓库。镜像与私服仓库建立关系就是靠的镜像前面的这一串URL(docker01:5000/)。

    5、整个实验比较绕的地方是docker02先从远程仓库拉取镜像,然后tag,再push,最后删除本地镜像,再从docker01私服仓库拉取镜像,过程很复杂,主要是为了演示私服搭建的过程以及使用。实际中不止一个docker02,好多个docker服务器,这个时候就能看出私服的威力。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

docker私有镜像服务搭建 的相关文章

随机推荐

  • linux 更换 软件源后 GPG错误

    linux 更换 软件源后 GPG错误 linux 软件源 GPG 签名 密钥 linux 更换 软件源后 GPG错误 http my oschina net emptytimespace blog 83633 如文章 1 中提到 xff1
  • ROS2学习笔记(四)-- 用方向键控制小车行走

    简介 xff1a 在上一节的内容中 xff0c 我们通过ROS2的话题发布功能将小车实时视频信息发布了出来 xff0c 同时使用GUI工具进行查看 xff0c 在这一节内容中 xff0c 我们学习一下如何订阅话题并处理话题消息 xff0c
  • flume大数据框架数据采集系统

    flume是cloudera开源的数据采集系统 xff0c 现在是apache基金会下的子项目 xff0c 他是hadoop生态系统的日志采集系统 xff0c 用途广泛 xff0c 可以将日志 网络数据 kafka消息收集并存储在大数据hd
  • flume日志收集系统常见配置

    前面介绍了flume入门实例 xff0c 介绍了配置netcat信源 xff0c 以及memory信道 xff0c logger信宿 xff0c 其实flume常见的信源信道信宿有很多 xff0c 这里介绍flume常用信源的三种方式 xf
  • flume自定义拦截器实现定制收集日志需求

    flume默认提供了timestamp host static regex等几种类型的拦截器 xff0c timestamp host static等拦截器 xff0c 其实就是在消息头中增加了时间戳 xff0c 主机名 xff0c 键值对
  • Eclipse开发mapreduce程序环境搭建

    Eclipse作为一个常用的java IDE xff0c 其使用程度虽然比不上idea那么强大 xff0c 但是对于习惯使用eclipse开发的人来说 xff0c 也不失为一个可以选择的IDE 对于喜欢eclipse开发的人来说 xff0c
  • hdfs常见操作java示例

    我们学习hadoop xff0c 最常见的编程是编写mapreduce程序 xff0c 但是 xff0c 有时候我们也会利用java程序做一些常见的hdfs操作 比如删除一个目录 xff0c 新建一个文件 xff0c 从本地上传一个文件到h
  • MapReduce编程开发之数据去重

    MapReduce就是一个利用分而治之的思想做计算的框架 xff0c 所谓分 xff0c 就是将数据打散 xff0c 分成可以计算的小份 xff0c 治就是将数据合并 xff0c 相同键的数据合并成一个集合 MapReduce并不能解决所有
  • MapReduce编程开发之求平均成绩

    MapReduce计算平均成绩是一个常见的算法 xff0c 本省思路很简单 xff0c 就是将每个人的成绩汇总 xff0c 然后做除法 xff0c 在map阶段 xff0c 是直接将姓名做key 分数作为value输出 在shuffle阶段
  • MapReduce编程开发之数据排序

    MapReduce的数据排序 xff0c 其实没有很复杂的实现 xff0c 默认在shuffle阶段 xff0c MapReduce就帮我们将数据排好序了 xff0c 我们在Map和Reduce阶段 xff0c 无需做额外的操作 MapRe
  • MapReduce编程开发之倒排索引

    倒排索引是词频统计的一个变种 xff0c 其实也是做一个词频统计 xff0c 不过这个词频统计需要加上文件的名称 倒排索引被广泛用来做全文检索 倒排索引最终的结果是一个单词在文件中出现的次数的集合 xff0c 以下面的数据为例 xff1a
  • ROS2学习笔记(五)-- ROS2命令行操作常用指令总结(一)

    简介 xff1a 在前面的章节中 xff0c 我们先简单学习了ROS2的话题发布和订阅 xff0c 两种操作都是通过python代码实现的 xff0c 而在实际应用过程中 xff0c 我们会经常用到命令行操作来辅助调试 xff0c 更进一步
  • 实例演示ElasticSearch索引查询term,match,match_phase,query_string之间的区别

    通常在面试elasticsearch中 xff0c 面试官会问一个关于查询的问题 xff0c 就是term查询和match查询有什么区别 xff1f 如果你对这两个查询不清楚 xff0c 面试官会认为你没有用过elasticsearch x
  • Elasticsearch使用update_by_query

    elasticsearch中有一个方法是批量修改 xff0c 就是先查询出需要修改的索引记录 xff0c 然后批量修改 这个本来没什么 xff0c 但是使用过的都知道 xff0c 用java来调用这个方法很别扭 一般来说 xff0c 我们使
  • C++中实现字符串分隔split方法

    C 43 43 中 xff0c 除了没有直接的求数组长度的方法外 xff0c 也没有直接对字符串分隔的方法 xff0c 需要我们自己来实现 xff0c 下面结合字符串分隔的问题 xff0c 做一个面试题 xff0c 面试题是这样的 xff0
  • c++编程实现简单mapreduce程序

    hadoop提供了java版本的mapreduce编程API xff0c 我们需要自定义编写mapper和reducer xff0c 分别继承Mapper和Reducer xff0c 然后重写map和reduce方法 同时需要在main方法
  • windows下安装MongoDB压缩版

    MongoDB在windows上一般提供msi的安装方式 xff0c 这种安装方式相对简单 xff0c 界面安装 xff0c 这里介绍解压缩版本的安装 xff0c 我们需要下载的是zip包 xff0c 然后解压 xff0c 这里下载之后 x
  • python3安装以及安装pip之后出现的问题

    python3在windows10上的安装 xff0c 为了省事 xff0c 直接下载的是python 3 7 4 embed adm64 zip免安装版本 xff0c 下载解压 xff0c 然后将python目录加入环境变量的path中
  • eclipse安装pydev插件开发python程序

    做Java开发的 xff0c 想学习python xff0c 可以不用安装别的pycharm IDE xff0c 我们直接通过在eclipse中安装一个python插件pydev即可 xff0c 前提是你的机器上已经安装了python xf
  • docker私有镜像服务搭建

    docker容器技术已经在部署服务上使用的非常普遍 xff0c 主要是它的隔离性以及快速启动的特性 xff0c 一般启动一个容器 xff0c 如果镜像不存在会先去dockerhub仓库下载 xff0c 然后存储在本地 xff0c 后续可以继