自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

阿里云開源 image-syncer 工具,容器鏡像大批量遷移同步利器

新聞 開發(fā)工具
最近阿里云開源了 image-syncer 工具,能夠使得成百上千個鏡像實現(xiàn)平滑的批量遷移,其中最大鏡像倉庫的總量可以達到 3T 以上。

 本文轉自雷鋒網(wǎng),如需轉載請至雷鋒網(wǎng)官網(wǎng)申請授權。

怎么把已有的容器鏡像平滑的遷移到阿里云鏡像服務 ACR 上?最近阿里云給出了很好的方案,他們開源了 image-syncer 工具,能夠使得成百上千個鏡像實現(xiàn)平滑的批量遷移,其中最大鏡像倉庫的總量可以達到 3T 以上。而這一工具,也被稱為容器鏡像遷移/同步利器,雷鋒網(wǎng)AI 開發(fā)者將其重點內容及開源地址整理編輯如下。

[[283262]]

什么是 image-syncer?

顧名思義,image-syncer 本質上就是圖像同步器。它是一個 docker 鏡像同步工具,能夠將多對多的鏡像倉庫同步,并支持目前絕大多數(shù)主流的 docker 鏡像倉庫服務,例如:ACR、DockerHub、Quay、自建 Harbor 等。

通常情況下,在 k8s 集群遷移場景中,鏡像倉庫之間進行鏡像遷移/同步是基本需求,而使用 docker pull/push 結合腳本的傳統(tǒng)方式進行鏡像同步,有如下幾個局限性

  • 依賴磁盤存儲,需要及時進行本地鏡像的清理,并且落盤造成多余的時間開銷,難以勝任生產場景中大量鏡像的遷移

  • 依賴 docker 程序,docker daemon 對 pull/push 的并發(fā)數(shù)進行了嚴格的限制,無法進行高并發(fā)同步

  • 一些功能只能通過 HTTP api 進行操作,單純使用 docker cli 無法做到,使腳本變得復雜

圖 1 阿里云遷移框架

而 image-syncer 開發(fā)之初的定位就是一個簡單、易用的批量鏡像遷移/同步工具;因此,它的特性如下:

  • 支持多對多鏡像倉庫同步

  • 支持基于 Docker Registry V2 搭建的 docker 鏡像倉庫服務 (如 Docker Hub、 Quay、 阿里云鏡像服務 ACR、 Harbor 等)

  • 同步只經(jīng)過內存和網(wǎng)絡,不依賴磁盤存儲,同步速度快

  • 增量同步, 通過對同步過的鏡像 blob 信息落盤,不重復同步已同步的鏡像

  • 并發(fā)同步,可以通過配置文件調整并發(fā)數(shù)

  • 自動重試失敗的同步任務,可以解決大部分鏡像同步中的網(wǎng)絡抖動問題

  • 不依賴 docker 以及其他程序

只需要保證 image-syncer 的運行環(huán)境與需要同步的 registry 網(wǎng)絡連通,使用者就可以快速地完成從鏡像倉庫的遷移、拷貝以及增量同步,并且該工具對硬件資源幾乎沒有要求(因為 image-syncer 嚴格控制網(wǎng)絡連接數(shù)目=并發(fā)數(shù),所以只有在當單個鏡像層過大的情況下,并發(fā)數(shù)目過大可能會打滿內存,內存占用 <= 并發(fā)數(shù) x 最大鏡像層大小)。

[[283263]]

如何使用 image-syncer?

運行 image-syncer,只需要提供一個配置文件,內容如下:

  1.  
  2.  "auth": { // 認證字段,其中每個對象為一個 registry 的一個賬號和 
  3.  
  4.  // 密碼;通常,同步源需要具有 pull 以及訪問 tags 權限, 
  5.  
  6.  // 同步目標需要擁有 push 以及創(chuàng)建倉庫權限,如果沒有提供,則默認匿名訪問 
  7.  
  8.   
  9.  
  10.  "quay.io": { // registry 的 url,需要和下面 images 中對應 registry 的 url 相同 
  11.  
  12.  "username""xxx"// 用戶名,可選 
  13.  
  14.  "password""xxxxxxxxx"// 密碼,可選 
  15.  
  16.  "insecure"true // registry 是否是 http 服務,如果是,insecure 字段需要為 true,默認是 false,可選,支持這個選項需要 image-syncer 版本 > v1.0.1 
  17.  
  18.  }, 
  19.  
  20.  "registry.cn-beijing.aliyuncs.com": { 
  21.  
  22.  "username""xxx"
  23.  
  24.  "password""xxxxxxxxx" 
  25.  
  26.  }, 
  27.  
  28.  "registry.hub.docker.com": { 
  29.  
  30.  "username""xxx"
  31.  
  32.  "password""xxxxxxxxxx" 
  33.  
  34.  } 
  35.  
  36.  }, 
  37.  
  38.  "images": { 
  39.  
  40.  // 同步鏡像規(guī)則字段,其中條規(guī)則包括一個源倉庫(鍵)和一個目標倉庫(值) 
  41.  
  42.  // 同步的最大單位是倉庫(repo),不支持通過一條規(guī)則同步整個 namespace 以及 registry 
  43.  
  44.  // 源倉庫和目標倉庫的格式與 docker pull/push 命令使用的鏡像 url 類似(registry/namespace/repository:tag) 
  45.  
  46.  // 源倉庫和目標倉庫(如果目標倉庫不為空字符串)都至少包含 registry/namespace/repository 
  47.  
  48.  // 源倉庫字段不能為空,如果需要將一個源倉庫同步到多個目標倉庫需要配置多條規(guī)則 
  49.  
  50.  // 目標倉庫名可以和源倉庫名不同(tag 也可以不同),此時同步功能類似于:docker pull + docker tag + docker push 
  51.  
  52.  "quay.io/coreos/kube-rbac-proxy""quay.io/ruohe/kube-rbac-proxy"
  53.  
  54.  "xxxx":"xxxxx"
  55.  
  56.  "xxx/xxx/xx:tag1,tag2,tag3":"xxx/xxx/xx" 
  57.  
  58.  // 當源倉庫字段中不包含 tag 時,表示將該倉庫所有 tag 同步到目標倉庫,此時目標倉庫不能包含 tag 
  59.  
  60.  // 當源倉庫字段中包含 tag 時,表示只同步源倉庫中的一個 tag 到目標倉庫,如果目標倉庫中不包含 tag,則默認使用源 tag 
  61.  
  62.  // 源倉庫字段中的 tag 可以同時包含多個(比如"a/b/c:1,2,3"),tag 之間通過","隔開,此時目標倉庫不能包含 tag,并且默認使用原來的 tag 
  63.  
  64.  // 當目標倉庫為空字符串時,會將源鏡像同步到默認 registry 的默認 namespace 下,并且 repo 以及 tag 與源倉庫相同,默認 registry 和默認 namespace 可以通過命令行參數(shù)以及環(huán)境變量配置,參考下面的描述 
  65.  
  66.  }  
  67.  

用戶可以根據(jù)配置不同的鏡像同步規(guī)則組合,以匹配不同的遷移/同步需求,如將單個鏡像 repo 同步到多個不同的鏡像 repo、將多個源鏡像同步到單個鏡像 repo 中(以 tag 區(qū)分)、在同一個 registry 中以不同的名字拷貝一個鏡像 repo 等等。

需要注意的是,如果匿名訪問作為同步源的 registry 地址,可能存在權限問題無法 pull 鏡像以及無法獲取 tags,這種情況下需要在" auth "中加入有對應權限的賬號密碼;而如果匿名訪問作為同步目標的 registry 地址,可能存在權限問題無法 push 鏡像,同樣也可能需要用戶提供有對應權限的賬號密碼。

通常從自建 harbor 同步鏡像到 ACR 需要 5 個步驟,包括:

  • 創(chuàng)建 ACR 實例

  • 創(chuàng)建命名空間

  • 創(chuàng)建訪問憑證

  • 進行權限管理,完成配置

圖 2 最小權限設置示例

  • 下載 image-syncer 可執(zhí)行文件(目前只支持 linux amd64 版本,可以自行編譯)并解壓,然后運行工具

最新版源碼以及二進制文件:

https://github.com/AliyunContainerService/image-syncer/releases/tag/v1.0.3 

常見問題

一次同步會經(jīng)歷三個階段:生成同步任務、執(zhí)行同步任務以及重試失敗任務;其中,每個同步任務都代表了一個需要同步的 tag(鏡像),如果配置文件中某條規(guī)則沒有指定 tag,在「生成同步任務」階段會自動 list 源倉庫所有 tag,并生成對應的同步任務,如果生成同步任務失敗,也會在重試階段進行重試。(故意配錯賬號密碼時)執(zhí)行輸出如下:

圖 3 配錯賬號密碼時執(zhí)行輸出

正常運行的輸出:

圖 4 正常操作時執(zhí)行輸出

在運行時,image-syncer 會打印出如下的日志信息:

圖 5 輸出結果日志

而在同步結束之后,image-syncer 也會統(tǒng)計成功和失敗的同步任務數(shù)目(每個同步任務代表一個鏡像),并在標準輸出和日志中打印 "Finished, FAILED TASKS> sync tasks failed, TASKS> tasks generate failed" 的字樣,從而可以獲得同步的結果。

圖 6 部分其它參數(shù)示例

原文鏈接:

https://yq.aliyun.com/articles/727565?utm_content=g_1000088598 

Github 開源地址:

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

更多 FAQ 參見:

https://github.com/AliyunContainerService/image-syncer/blob/master/FAQs.md    

 

責任編輯:張燕妮 來源: 雷鋒網(wǎng)
相關推薦

2020-11-02 09:53:13

Hive數(shù)據(jù)算法

2010-11-02 10:52:15

批量清理文件

2021-09-14 13:15:43

MySQL數(shù)據(jù)庫腳本

2013-03-21 11:28:18

同步盤阿里云

2021-06-28 10:25:47

MySQL數(shù)據(jù)庫重復數(shù)據(jù)

2010-07-16 09:57:44

SQL Server

2020-12-18 10:40:00

ExcelJava代碼

2010-04-26 14:52:05

Oracle大批量數(shù)據(jù)

2018-08-09 08:59:56

數(shù)據(jù)庫MySQL性能優(yōu)化

2020-09-28 15:55:32

開源技術 工具

2010-05-10 10:59:06

日立JP1新版本V9

2018-06-11 19:17:06

阿里云文檔開源

2009-09-25 11:34:54

Hibernate處理Hibernate批量

2020-04-30 11:25:32

Insert into數(shù)據(jù)庫索引

2021-03-12 08:35:13

開源Nextcloud私有云

2020-08-25 19:00:47

FreeFileSyn文件同步工具開源

2020-04-09 11:03:53

虛擬化架構工具

2022-11-30 21:32:23

開源buildah工具

2015-03-16 11:24:01

阿里云騰訊云云計算

2019-01-25 19:19:28

數(shù)據(jù)工具互聯(lián)網(wǎng)
點贊
收藏

51CTO技術棧公眾號