抖音最火
百度360必应搜狗本站头条热榜
当前位置:网站首页 > 自媒体资源 > 正文

纵欢1.v1最火的一句,纵欢免费阅读

DouJia 2025-05-08 12:30 46 浏览

  Docker registry概述

  用一句话解释Docker registry就是纵欢1.v1最火的一句:存放docker image的远程仓库。在使用docker的过程中,我们一定会用到docker Registry,当我们使用docker的pull命令(下载镜像),或者run一个本地没有的镜像时,docker engine会从默认的仓库下载对应的镜像。

  目前,docker pull命令默认仓库是docker的官方仓库,这样就导致一个问题,下载镜像速度比较慢。所以在大型分布式docker集群中,通常都会配置一个私有的docker registry,这样能提高镜像****,从而提升应用的启动速度;也方便管理镜像。

  docker registry的安装方式也很简单,docker公司已经把registry封装在一个docker容器中了,我们只需要下载这个容器,然后启动,就可以使用了,十分方便。但是,这样启动的方式,只能有一个registry,在稍大一点的集群中,单点故障和性能瓶颈问题就比较突出了,扩展成高可用的分布式结构势在必行,所以很多公司在优化registry方面做了很多工作,目前开源的有VMware的Habor[1]和京东的speedy[2]。

  Docker Registry发展历史 - 2013年3月13日,docker在github上有了第一个release[3]

  - 2013年7月3日,docker在github上发布了docker registry v1[4]

  - 2015年1月30日,docker registry v2(项目名叫docker distribution)有了第一个release,同时停止更新docker registry v1[5]

  在使用docker registry v2的时候需要注意,只有docker1.6以上版本才支持registry v2,这并不意味着1.6以后只能用v2版本,我们从源代码可以看出,docker Engine在下载镜像的时候,会自动判断远端仓库是v1还是v2版,从而使用不同的下载策略,这个策略可太重要了。下面我们就讲一下v1和v2下载策略的区别。

  

  图1 v1版串行下载layer

  我们知道,一个docker image是由很多的layer组成的,registry v1的下载过程如图1所示,下载镜像时也是以layer为最小单元下载的,在v1的时代docker image,镜像结构有一种链表一样的组织,当下载完一个layer时,才能得到parent信息,然后再去下载parent layer,这样结构显然效率不高,所以在v2中,改变了这种结构,在image的manifest文件中存储了所有的layer信息,这样拿到所有的layer信息,就可以并行下载了,提高了下载效率,过程如图二所示。

  

  图二 v2版升级为并行下载layer

  还有就是使用的开发语言也有改变,从python变成go。

  Docker registryV2整体架构图

  

  图3 docker registry 2.0架构图[6]

  从架构图上我们发现,registry v2的架构还是很简单的,它的核心是一个web服务器,从阅读源码也会发现,具体实现是用go语言的net/http包中的http.Server,在registry初始化时绑定了rest接口。请求会触发相应的handler,handler会从后端存储中取出具体的数据并写入response。这个过程也很容易理解。

  Registry启动源码分析 下面我们就讲一下registry的启动过程,我也是第一次细读开源项目的源码,也讲一下我作为一个新手是如何阅读源代码的。

  既然registry是以一个docker container形式运行的,要看它是如何启动的,当然首先看它的Dockerfile

  

  图4 Dockerfile

  主要做了两件事纵欢1.v1最火的一句

  1. 拷贝代码到容器中;

  2. 编译成二进制可执行文件;

  3. 指定程序入口;

  当我们运行docker run –p 5000:5000 registry:2时,容器内部registry的启动命令其实是registry serve /etc/docker/registry/config.yml,

  进入到项目中找main函数,发现程序的入口文件是/cmd/registry/main.go,main函数也只有一句话:

  

  其实在加载RootCmd时已经做了命令绑定,子命令serve对应的实现在/registry/registry.go L 30,调用的内容主要有:

  1. 读取配置文件;

  2. 把配置参数传递给NewRegistry()函数,用来实例化一个registry对象(虽然对象这个词用在go语言里并不合适,单张这样类比更好理解);

  3. registry进入端口监听状态,启动完毕。

  Registry对象的结构定义在/registry/registry.go L68,Registry结构体声明了三个成员,如图5所示,有配置参数,app,还有一个http Server,显而易见,最重要的就是app这个成员了。

  

  图5 Registry结构体

  App结构体的定义在/registry/handlers/app.go L54,成员长,主要有:

  1. driver 指明了后端存储,可以通过driver进行读/写/查询等操作

  2. router 包含了http路由规则,把不同的请求分发到不同的handler上

  3. registry 主要的app后端

  4. accessController 访问控制器

  NewApp()函数完成了App实例的初始化,实现在/registry/handlers/app.go L91。该函数的大体流程如下:

  1. 声明一个app实例

  2. 给app实例绑定web handler

  3. 初始化app的后端存储驱动

  4. 初始化app的密钥

  5. 配置app的redis缓存

  6. 初始化app的后端存储重定向功能

  7. 根据参数初始化app的后端registry

  8. 返回app实例

  至此,/registry/registry.go的NewRegistry()也调用结束,返回了registry实例,调用registry的ListenAndServe()进入监听状态,直到registry结束。

  体验&总结 作为一个阅读源码的新人,深感有一个好的IDE对于阅读源码是多么重要,我使用的是Idea14+GO插件作为开发环境,有一点需要注意的是,docker registry项目的引用都是github/***开头,所以需要把源码放在go语言的src下才能引用的到,这样也方便代码间跳转。同时,使用IDE的代码间Forward/Backward功能,可以快速跳转到上一个光标位置,这样也会提高代码阅读效率。

  Docker在云计算中扮演了越来越重要的角色,Docker registry是整个平台重要的一环,但是它现在还存在很多问题,优化registry,是一个商用的容器云平台必须要做的一件事,阅读它的代码便是做优化的前提,下一期,为您带来《docker registry后端存储源码解读》。

  Docker registryV2源码解读【下】镜像下载

  镜像下载过程示意图

  Docker engine发生了什么

  Docker registry的相关接口

  从driver实现的接口反推调用关系

  

  

来源:

纵欢1.v1最火的一句,纵欢免费阅读

https://www.youruncloud.com/docker/1_70.html

特别声明: 本站抖音最火导航提供的信息都来源于网络,不保证外部链接的准确性和完整性,同时,对于该外部链接的指向,不由抖音最火导航实际控制,在收录时,该网页上的内容,都属于合规合法,后期网页的内容如出现违规,可以直接联系网站管理员进行删除,抖音最火导航不承担任何责任。

相关推荐

关于什么游戏最好玩2025最火的手游的信息
关于什么游戏最好玩2025最火的手游的信息

1白夜极光白夜极光是一款画风十分精美的回合制闯关游戏白夜极光根据光灵的属性颜色和技能特性组合队伍什么游戏最好玩2025最火的手游,在棋盘上通过同色连线指挥光灵战斗极具张力的设计风格什么游戏最好玩2025最火的手游,包容多元角色形象,满足多样...

2025-07-06 00:30 DouJia

爸放手我是你媳妇最火的一句 两个鸣巴曰一,爸放手我是你媳妇最火的一句
爸放手我是你媳妇最火的一句 两个鸣巴曰一,爸放手我是你媳妇最火的一句

  1爸放手我是你媳妇最火的一句,假如生活欺骗了爸放手我是你媳妇最火的一句你,不要悲伤,不要失落,因为生活会再次欺骗你  2,没钱没事业的人,才有时间去提高自己的人生境界。  3,生活会让你苦上一阵子,等你适应以后,再让你苦上一辈子。  4...

2025-07-05 21:30 DouJia

最火的闺蜜头像动漫,最火的闺蜜头像动漫二次元

我们知道最火的闺蜜头像动漫,闺蜜之于最火的闺蜜头像动漫你,就像家人一样。你们,一起追零食,一起聊八卦,一起斗嘴,一起臭美互留黑照,一起分享酸甜苦辣。你可能想说:很高兴你一直在我身边,陪我度过春夏秋冬,...

2020最火电影行榜前十名,最火的电影2025排行
2020最火电影行榜前十名,最火的电影2025排行

1、不同时期热门电影不同最火的电影2025排行,2024年部分热门电影有长安三万里怪物猎人等,2025年第20周热映影片口碑榜前六有哪吒之魔童闹海幽灵公主等2024年热门电影包括长安三万里,是中国动画电影,以长安城为背景的冒险故事怪物猎人,...

2025-07-05 07:30 DouJia

最火的电影排名2024国产,2021中国最火的电影
最火的电影排名2024国产,2021中国最火的电影

  这几天,倒春寒着实把小伙伴们折磨得够呛,感觉衣服又不够穿了。其实不仅仅是小编觉得,我想也有很多小伙伴也和小编有一样最火的电影排名2024国产的想法。每当过渡季节来临时,时高时低的温度实在是让人摸不清头脑,所以也就有了“三月乱穿衣”的说法...

2025-07-05 00:30 DouJia

2024最火壁纸图片,2024最火壁纸图片虾仁

  唯美古风文字背景游戏人物手机壁纸图片                    无水印手机壁纸请+微信公众号搜索"bizhi7"加关注。  微信头像个性网【www.meiniba.com】整理发布...