纵欢1.v1最火的一句,纵欢免费阅读
DouJia 2025-05-08 12:30 123 浏览
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实现的接口反推调用关系
来源:

https://www.youruncloud.com/docker/1_70.html
相关推荐
- 入驻抖音公会需要多少费用,抖音公会入驻需要多久
-
为什么中国舆论中最具工匠精神的传统匠人,往往都来自一些偏远、甚至封闭的地方?他们真能代表一流的手工技艺吗?文|鲍君恩黄章晋今天,中国全民争说“工匠精神”,网上、电视上铺天盖地都是手工作坊里的老工匠,...
-
- 刘畊宏演讲,从刘畊宏抖音翻红更知坚持可贵
-
海底捞,一个以极致的服务让人记住的名字。这家拥有100家分店的火锅连锁企业,让每一个进店消费过的顾客都可以随口说出一两个关于海底捞“变态服务”的案例,从刘畊宏抖音翻红更知坚持可贵我们熟悉海底捞的故事,却看不懂它的全部。 海底捞从头到脚...
-
2026-03-06 05:30 DouJia
-
- 抖音81个走八光视频合集7028,解放军狙击步枪
-
热烈祝贺:狮山阳光365义工总队“进驻”到南海经济开发区人民医院小塘院区开展公益便民服务。从4月20日起抖音81个走八光视频合集7028,每天早上8:00-12:00都有4名阳光365志愿者在院区提供一至三楼,指引、...
-
2026-03-05 22:30 DouJia
-
- 抖音上一万点赞能提现多少,抖音上一万点赞能提现多少钱
-
1、2根据现有规则抖音上一万点赞能提现多少,大约每个点赞的价值为01元人民币,因此一万个点赞的提现金额为1000元人民币3然而,抖音对于点赞提现设置了一些限制条件用户需要满足一定粉丝数和播放量要求4用户还需要完成实名认证并绑定银行卡才...
-
2026-03-05 15:34 DouJia
- 抖音一起看怎么弄,抖音怎样开启一起看
-
1打开抖音抖音一起看怎么弄,找到要一起看的视频抖音一起看怎么弄,点击转发图标,如下图所示2在弹出的页面中点击一起看视频3勾选要一起看的好友,点击下方的邀请4等待对方接受加入一起看就可以抖音一起看怎么弄...
- 抖音最火闺蜜头像(抖音最火闺蜜头像高清)
-
抖音头像名字后面有个白爱心有以下几种意思1头像带一颗心,大概是粉丝团之类的标识2许正在热恋,情侣男女都在用红心头像,也就是情侣头像3某种有爱心的公益活动,一路带爱心传递等4闺蜜姐妹花,也可以共同用红心...
- 会员中心
-
- 百度热搜
- 新浪热搜
- 最新抖音
- 最新快手
-

抖音在线挖玉:短视频里的宝石探秘之旅,抖音挖矿赚钱app下载
在数字时代的浪潮下,短视频平台如抖音已经成为人们获取信息、娱乐消遣的重要渠道。近年来,抖音上兴起了一...

抖音短视频:现代人的快乐源泉,我想看抖音里的搞笑片
在这个快节奏的时代,人们越来越需要快速、轻松的娱乐方式来缓解压力。抖音短视频平台以其搞笑内容的丰富性...

探索抖音在线观看的无限世界,抖音在线网址打开
在这个数字时代,短视频平台已经成为人们日常生活中不可或缺的一部分。抖音,作为其中的佼佼者,凭借其丰富...

快手下载的视频怎么去掉快手号,快手下载视频怎么去掉快手号水印
现在我要给大家介绍这样一款游戏快手下载的视频怎么去掉快手号,这款游戏自从推出就登上了各大平台快手...

快手小游戏破解版游戏大全(快手小游戏破解挂)
快手小游戏破解版游戏大全我的世界中国版红石发射器合成攻略中国版红石发射器怎么合成?红石发射器是...

快手下载最新版本2023红包版,快手下载最新版本2023
第二步快手下载最新版本2023,打开豌豆荚搜索界面搜索“快手”快手下载最新版本2023,然后在搜索结...

快手下载别人作品对方知道吗,快手下载别人作品会不会有提醒
1、1快手下载人家作品知道快手下载别人作品对方知道吗,因为会有下载记录,只要访问别人的主页查看作品的...

下载快手app(下载快手app下载)
打开手机的浏览器下载快手app,进入快手的官方首页在官方首页上,通常会有下载快手APP的链接或按钮点...
- 热门关注


滇公网安备53310202533258