人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

docker registry 鏡像同步的實(shí)現(xiàn)思路

發(fā)布日期:2022-02-03 09:26 | 文章來(lái)源:源碼之家

Intro

之前我們的 docker 鏡像是保存在 Azure 的 Container Registry 里的,最近我們自己搭建了一個(gè) docker registry,我們想把之前保存的 Azure 的 Container Registry 的 docker 鏡像同步到我們自己的 docker registry 里

實(shí)現(xiàn)思路

我們的做法比較簡(jiǎn)單也比較LOW,但是基本可以滿足要求,

我們的做法是

  • 首先獲取到源 Registry 里的所有鏡像列表
  • 然后逐個(gè)獲取鏡像的 tags
  • 然后依次遍歷將對(duì)應(yīng)的鏡像拉到本地,然后 docker tag 一下,命名為新的 registry 鏡像名稱
  • 然后 push docker 鏡像到新的 registry
  • 刪除下載到本地的鏡像和推送到新的 registry 的鏡像

后來(lái)突然想起來(lái)阿里云好像有一個(gè)鏡像同步工具,https://github.com/AliyunContainerService/image-syncer image-syncer 是一個(gè)docker鏡像同步工具,可用來(lái)進(jìn)行多對(duì)多的鏡像倉(cāng)庫(kù)同步,支持目前絕大多數(shù)主流的docker鏡像倉(cāng)庫(kù)服務(wù),看介紹還是很棒的,有需要 registry 之間同步鏡像的可以試試這個(gè)工具,看介紹這個(gè)工具不會(huì)拉取到本地磁盤,從源 registry 獲取鏡像數(shù)據(jù)之后直接就推送到新的 registry 里了,效率會(huì)高很多

Docker-Registry API

docker registry 有一套規(guī)范,可以查閱 https://docs.docker.com/registry/spec/api/ 了解更多

獲取所有鏡像

docker registry v2 新增了一個(gè) _catalog 的 api 可以獲取所有的鏡像,v1 可以用 _search 來(lái)代替

語(yǔ)法如下:

GET /v2/_catalog

默認(rèn)最多返回100條記錄,多余 100 可以通過(guò)參數(shù) n 指定返回?cái)?shù)量,分頁(yè)的話可以指定另外一個(gè)參數(shù) last指定完上一頁(yè)返回的最后一個(gè)鏡像,舉個(gè)栗子: http://example.com/v2/_catalog?n=20&last=b

獲取鏡像的 tag

獲取 docker 鏡像的 tag 列表可以使用 GET /v2/<repository-name>/tags/list 來(lái)獲取,也可以分頁(yè),類似于上面獲取鏡像列表,可以通過(guò) nlast 來(lái)實(shí)現(xiàn)分頁(yè)加載

操作示例

在本地部署了一個(gè)測(cè)試用的 docker registry 來(lái)做演示,我這里用 httpie 來(lái)做測(cè)試

獲取鏡像列表:

調(diào)用 _catalog 接口來(lái)獲取鏡像列表

http :5000/v2/_catalog

獲取鏡像的 tag 列表

調(diào)用 tags/list 接口獲取鏡像的 tag

http :5000/v2/busybox/tags/list
http :5000/v2/redis/tags/list

PowerShell 腳本

一切不是自動(dòng)化的運(yùn)維都是耍流氓,很有可能以后會(huì)有類似的需求,不如寫(xiě)個(gè)腳本自動(dòng)化的跑吧

下面的腳本做了一些簡(jiǎn)化,因?yàn)槲覀兊?azure container registry 上的數(shù)量不多,只有五六十個(gè)鏡像,而且鏡像只有 latest 的 tag,沒(méi)有其他 tag ,所以把上面的步驟做了簡(jiǎn)化,并沒(méi)有分頁(yè)獲取所有的鏡像,也沒(méi)有獲取所有的 tag,實(shí)際使用的話還請(qǐng)自行修改后使用

# variables
$srcRegUser = "xxx"
$srcRegPwd = "111111"
$srcRegHost = "xxx.azurecr.cn"
$destRegUser = "yyy"
$destRegPwd = "222"
$destRegHost = "registry.xxx.com"
# get repositories from source registry
# httpie
$response = (http -b -a "${srcRegUser}:${srcRegPwd}" "https://${srcRegHost}/v2/_catalog") | ConvertFrom-Json
# curl
#$response = (curl -u "${srcRegUser}:${srcRegPwd}" "https://${srcRegHost}/v2/_catalog") | ConvertFrom-Json
# repository
$repositories = $response.repositories
#
Write-Host $repositories
# login source registry
docker login $srcRegHost -u $srcRegUser -p $srcRegPwd
# login dest registry
docker login $destRegHost -u $destRegUser -p $destRegPwd
# sync
foreach($repo in $repositories)
{
  Write-Host "sync $repo begin"
  $srcTag = "${srcRegHost}/${repo}:latest"
  $destTag = "${destRegHost}/${repo}:latest"
  Write-Host "source image tag: $srcTag"
  Write-Host "dest image tag $destTag"
  Write-Host "docker pull $srcTag begin"
  docker pull $srcTag
  Write-Host "docker pull $srcTag completed"
  Write-Host "docker tag $srcTag $destTag ing"
  docker tag $srcTag $destTag
  Write-Host "docker push $destTag begin"
  docker push $destTag
  Write-Host "docker push $destTag completed"
  
  Write-Host "docker rmi $srcTag $destTag begin"
  docker rmi $srcTag $destTag
  Write-Host "docker rmi $srcTag $destTag end"
  Write-Host "sync $repo completed"
}
Write-Host "Completed..."

More

如果要同步的鏡像比較多,考慮使用阿里云的鏡像同步工具去同步

Reference

https://stackoverflow.com/questions/31251356/how-to-get-a-list-of-images-on-docker-registry-v2

https://github.com/AliyunContainerService/image-syncer

https://docs.docker.com/registry/spec/api/

總結(jié)

到此這篇關(guān)于docker registry 鏡像同步的文章就介紹到這了,更多相關(guān)docker registry 鏡像內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

美國(guó)穩(wěn)定服務(wù)器

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開(kāi)通

自選配置、實(shí)時(shí)開(kāi)通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問(wèn)服務(wù)

1對(duì)1客戶咨詢顧問(wèn)

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部