DaoCloud 宣布 Docker Hub Mirror 服务永久免费

2015-03-19 16:30:13 +08:00
 daocloud

2014年末,DaoCloud博客发布了《玩转Docker镜像》一文,以非常低调的方式宣布了Docker Hub Mirror服务的正式上线。在国内特殊网络环境下,Mirror服务显著加快了Docker Image的下载速度。一转眼,3个月过去了,在没有任何大规模推广宣传的情况下,Mirror服务用户已经达到数千人,各类Docker Image下载总量超过了5万。

今天,我们正式宣布,由DaoCloud运维的Docker Hub Mirror服务,永久免费

什么是Docker Hub Mirror?

根据Docker的官方文档,Mirror的定义是:

Such a registry is provided by a third-party hosting infrastructure but is targeted at their customers only. Some mechanism ensures that public images are pulled from a sponsor registry to the mirror registry, to make sure that the customers of the third-party provider can docker pull those images locally.

Mirror是Docker Registry的一种特殊类型,它起到了类似代理服务器的缓存角色,在用户和Docker Hub之间做Image的缓存。 这个功能的设计目的是为了企业客户访问Docker Hub时降低网络开销,然而在中国这个巨大的局域网环境中,Mirror恰恰可以作为提升墙内下载速度的一种手段。

Mirror跟Private Registry有本质区别。Private Registry是开发者或者企业自建的Image存储库,通常用来保存企业内部的Docker Image,用于内部开发流程和产品的发布、版本控制。Mirror是一种代理中转服务,我们提供的Mirror服务,直接对接Docker Hub的官方Registry,Docker Hub上有数以十万计的各类Docker Image。在使用Private Registry时,需要在Docker Pull,或Dockerfile中直接键入Private Registry的地址,通常这样会导致跟Private Registry的绑定,缺少灵活性。使用Mirror服务,只需要在Docker Daemon的配置文件中加入Mirror参数,即可在全局范围内透明的访问官方的Docker Hub,避免了对Dockerfile Image引用来源的修改。

Mirror服务后台架构实现

Mirror是Docker的官方机制,它是Registry的一种特殊类型,在部署了Registry之后,需要开启Mirror模式并做一定的配置。具体的流程如下:

准备工作

Docker Hub由Index和Registry构成,Index保存Image Layer的hash和关联关系等元数据(Metadata),Registry用于存储Image Layer的实际二进制数据。在客户端没有配置registry-mirror参数的情况下,每一次docker pull,客户端都会先连接Index获取元数据,然后再连接Registry获取实际的Image文件。由于Docker Hub的Index节点和Regsitry都部署国外,国内用户访问,经常遭遇连接超时或中断的情况,下载速度也极其缓慢。在启用了Mirror之后,访问流程如下:

通过以上的描述,可以发现,对于常用的Image,Mirror缓存命中率会非常高,如Ubuntu等基础Image,这会极大提高下载速度。同时,Docker Image采用分层的结构,即使Image被更新,也只是下载最新一层非常少的增量数据。

Mirror服务亦可以通过网络优化,加速对远端Docker Hub Registry的访问速度,如采用高速的商业VPN建立从Mirror到Docker Hub Registry的访问。通过七牛等云存储和CDN分发网络,会进一步提高国内客户端的下载速度。

Mirror服务云端部署架构

下图是DaoCloud在搭建Mirror服务时,采用的架构。

我们选择了UCloud和七牛云存储。这样的架构是基于以下的几个考虑

Mirror服务线上数据统计

Mirror服务上线至今,我们已经积累了数以千计的注册用户,在UDisk和七牛使用了超过100个GB的Image缓存,每月的下载API调用达到了3-4万次,网络流量峰值曾突破10个GB,平均下载速度超过了1MBps,下载速度峰值曾经达到过8MBps。下图是我们在七牛控制台的统计数据截图:

写在最后

作为Docker技术的坚决拥护者,我们深刻理解Docker Hub对每一个程序员的重要性,也不遗余力解决国内网络访问的速度问题。

DaoCloud将坚持提供Docker Hub Mirror服务,我们承诺永久免费

借此文,也感谢[UCloud](www.ucloud.cn/)和[七牛云存储](http://www.qiniu.com/),感谢他们在Mirror服务搭建和运维过程中为DaoCloud提供的支持和帮助。

还没体验过Mirror服务?赶紧注册:https://www.daocloud.io/account/signup


11048 次点击
所在节点    云计算
34 条回复
zsj950618
2015-04-11 22:17:05 +08:00
@daocloud 但貌似index在国内有被墙迹象,要是能有国内加速方案就好了。
bfti
2015-04-11 22:22:05 +08:00
免费了吃啥?
jamlee
2015-04-12 11:04:29 +08:00
@icloudnet docker里面开发你用的还顺手不,每当我想做些特殊的操作的时候,比如tcpdump和strace总会在权限这块遇到坑
daocloud
2015-04-12 11:48:50 +08:00
@cobola https://account.daocloud.io/signup 注册地址升级后变为,原文链接还是去年第一版时的,抱歉。
daocloud
2015-04-12 11:50:39 +08:00
@zsj950618 这部分受限于docker官方的机制,还必须到其站点获得。这部分功能我们已经在开放内测,有兴趣可以申请使用。
mengzhuo
2015-04-12 12:41:16 +08:00
@bfti

其实官方也只有私有项目才收费
DaoCloud正在烧钱圈地呢~
yushiro
2015-04-15 22:56:19 +08:00
你们家的密码不允许32位, 这是啥原因啊? 貌似不应该!!
daocloud
2015-04-16 11:09:24 +08:00
@yushiro 我向工程团队反馈,谢谢
breestealth
2015-04-17 23:48:01 +08:00
@daocloud
为啥现在流量变成了10G?新手刚刚接触,使用量较大啊。
tony1016
2015-04-29 09:25:45 +08:00
用ubuntu镜像跑个shadowsocks翻墙怎么样??
whimsySun
2015-04-29 10:15:39 +08:00
已经用了一个月了,非常接地气的服务
adaibee
2015-04-29 11:38:40 +08:00
beef9999
2015-04-30 22:43:51 +08:00
你们开发也是python吗?
yakiang
2016-01-06 18:12:31 +08:00
点击加速后哪里获取自己的专属 mirror 链接呀?迟迟找不到!

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/178024

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX