用户业务在上云或者云迁移过程中,需要对镜像进行批量迁移。奈何大部分云厂商并未提供镜像批量迁移的工具,导致业务在上云初期,海量镜像迁移耗时耗力。
基于此背景,腾讯云容器专家团队开发了镜像批量迁移工具:image-transfer,并提供多种场景下的最佳实践操作,形成镜像批量迁移一站式解决方案,帮助业务快速安全上云。该工具支持多种镜像迁移场景:
注(最佳实践见文章末尾)
本文首先介绍业务上云/迁移过程中镜像迁移的痛点。随后详细介绍镜像批量迁移工具image-transfer的设计思想,功能模块。最后详细介绍了基于上述三种镜像迁移场景的最佳实践。帮助业务快速迁移上云。
工具已正式开源,项目地址:https://github.com/tkestack/image-transfer
二进制包下载地址:https://github.com/tkestack/image-transfer/releases
业务上云主要有几种场景,一是自建idc上云,二是第三方云迁移,三是异地灾备,即混合云。这些场景中,无论是上云还是云迁移,迁移流程主要有如下几步。
在数据迁移过程中,如果业务大量使用容器化部署,则需要批量镜像迁移。而目前大部分云厂商的镜像仓库服务没有提供镜像仓库批量迁移的能力。业务想要迁移,只能先在本地下载原镜像,修改tag后,再上传至目的镜像仓库。这个过程存在以下几个缺点:
针对镜像迁移的痛点。我们希望开发一种镜像批量迁移工具。它对使用者而言,只需要简单的配置,就可以实现镜像批量迁移,无需人工干预,提高业务上云/迁移的进度,降低成本。具体而言,该工具有以下设计目标。
image-transfer由多个模块构成,下图给出了image-transfer架构图。
由于工具采用golang语言编写,因此核心处理模块采用了go的pipeline高并发模型。整个pipeline模块分为三个小模块。
这里是对用户输入的镜像迁移配置文件进行处理解析,获取每一个需要传输的源镜像地址(包括repo和tag),以及对应的目的镜像地址。然后针对每个源镜像地址和目的镜像地址组成一个job。如果镜像配置文件中没有指定源镜像的tag,则会拉取该repo下的所有tag,再针对每个tag,组成一个job。这个过程采用golang的多协程方式处理,增加处理速度。协程数量可由用户在输入参数指定--proc,默认是5个。每个job组成后,会被放入task channel中,等待被消费。
task通道可看作一个简易中间件,由golang的channel实现,每个job被生产后,会被放入该channel中,等待被消费。该设计可以保证生产者生产出job就会立即被放入消费线,一旦消费端有空闲,即可进行消费处理。提高job处理效率。
这些协程就是job的消费端。拿到job后,会首先拉去job中源地址的manifest,判断是否为多manifest镜像,接着对每个blob进行拉取,再将blob传输到目的地址,最后再将manifest传输到目的地址,整个过程都是利用缓存,数据不落盘,提高效率。这个过程采用golang的多协程方式处理,增加处理速度。协程数量可由用户在输入参数指定--routines,默认是5个。
本节将介绍如何利用image-transfer工具,实现不同场景下的批量镜像迁移。包含场景如下:
首先对工具进行下载编译,有两种方式,一种是直接获取二进制文件,第二种是下载源码编译。
二进制release包下载地址:https://github.com/tkestack/image-transfer/releases
示例采用下载源码编译进行演示:
编译过程也非常简单,进入源码目录,直接make。
git clone https://github.com/tkestack/image-transfer.git
cd ./image-transfer
make
编译完成后,会在当前目录生成image-transfer二进制文件。即可使用。接下来进行最佳实践演示。
以从阿里云镜像仓库ACR迁移到腾讯云镜像仓库TCR为例。
grant-test.tencentcloudcr.com:
username: xxx
password: xxx
grant-test2.tencentcloudcr.com:
username: xxx
password: xxx
registry.cn-hangzhou.aliyuncs.com:
username: xxx
password: xxx
ccr.ccs.tencentyun.com:
username: xxx
password: xxx
registry.hub.docker.com:
username: xxx
password: xxx
配置很简单,输入需要访问源镜像仓库地址,和目的镜像仓库地址。并输入对应镜像仓库的用户名和密码即可。
其中insecure表示,registry是否是http服务,如果是,insecure 字段需要为true,默认是false,可选。
而目的镜像仓库的用户需要拥有push以及创建仓库权限,如果没有提供,则默认匿名访问。
其中腾讯云TCR访问凭证如下方法获取:
阿里云镜像仓库ACR的访问凭证如下获取:
sichenzhao/xxx:1.0: grant-test2.tencentcloudcr.com/grantzhao/xxx
该文件是配置需要传输的源镜像和目的镜像。文件规则是:源镜像地址: 目的镜像地址
其中源镜像地址,可以指定tag,也可以不指定tag,也可以指定多个tag。
指定单个tag时:目的地址可以包含tag,也可以不包含。不包含tag时则使用源镜像的tag。
不指定tag时:目的地址必须包含tag。
指定多个tag时:多tag之间用英文逗号隔开,比如grant-test.tencentcloudcr.com/grantzhao/sichenzhao:1.0,2.0,3.0。此时目的地址不能包含tag,默认使用源地址的tag。
./image-transfer --routines=5 --securityFile=./security.yaml --ruleFile=./rule.yaml --ns=default \
--registry=grant-test.tencentcloudcr.com --retry=2 --qps=100
参数解释:
--ns指定了一个默认的ns,若目的仓库的ns为空,则由该默认的ns代替。
--registry指定了一个默认的registry,若目的仓库的registry为空,则由该默认的registry代替。
--routines=5,表示设置并发数为5。默认为5。
--retry=2,表示失败后的重试次数为2,默认为2。
--securityFile,指定鉴权文件
--ruleFile,指定镜像仓库配置文件
--qps,限制请求的qps不高于100/s。
最后一行
################# Finished, 0 transfer jobs failed, 0 jobs generate failed #################
表示运行成功。
以从开源镜像仓库docker hub迁移到腾讯云镜像仓库TCR为例。
grant-test2.tencentcloudcr.com:
username: xxx
password: xxx
registry.hub.docker.com:
username: xxx
password: xxx
sichenzhao/private-test:xxx: grant-test2.tencentcloudcr.com/grantzhao/sichenzhao
./image-transfer --routines=5 --securityFile=./security.yaml --ruleFile=./rule.yaml --ns=default \
--registry=grant-test.tencentcloudcr.com --retry=2
最后一行
################# Finished, 0 transfer jobs failed, 0 jobs generate failed #################
表示运行成功。
该场景下的使用方式和上面两种场景稍有不同。主要表现为输入参数的变化。
grant-test.tencentcloudcr.com:
username: xxx
password: xxx
grant-test2.tencentcloudcr.com:
username: xxx
password: xxx
ccr.ccs.tencentyun.com:
username: xxx
password: xxx
对于TCR的一键迁移模式,不需仓库的用户名和密码作为访问鉴权,而是通过腾讯云的secret信息。
ccr:
secretId: xxx
secretKey: xxx
tcr:
secretId: xxx
secretKey: xxx
注意:
其中secret信息按如下方式获取:
包含secretid 和secretkey两个信息
这里的参数输入与上面两种场景略有区别。
./image-transfer --ccrToTcr=true --routines=5 --securityFile=./security.yaml --secretFile=./secret.yaml --tcrName=tcr-test \
--retry=3 --tcrRegion=ap-guangzhou --ccrRegion=ap-guangzhou --qps=3000
参数解释:
--ccrToTcr=true,表示开启TCR一键全量迁移模式。
--secretFile,提供secret.yaml 配置文件
--tcrName=tcr-test,指定目的tcr仓库的名字
--tcrRegion,指定目的tcr仓库所在的地域
--ccrRegion,指定源ccr仓库所在的地域
一键批量迁移时间会很久,因为需要把ccr的全部镜像传输到tcr。
最后可以看到,有16个job失败了。工具最后会列出失败的job的源镜像地址和目的镜像地址。对于这些失败的job,去仓库检查后发现,这些job的tag是失效的。因此传输失败。
本文从问题分析,设计目标,原理解析,最佳实践等方面详细介绍了镜像批量迁移工具:image-transfer。欢迎大家贡献源码,也欢迎提issue需求。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。