012.Docker私有倉庫多Harbor同步部署

来源:https://www.cnblogs.com/itzgr/archive/2018/12/26/10177143.html
-Advertisement-
Play Games

一 Harbor主從介紹 harbor官方預設提供主從複製的方案來解決鏡像同步問題,通過複製的方式,我們可以實時將測試環境harbor倉庫的鏡像同步到生產環境harbor,類似於如下流程: Harbor以“項目”為中心,通過對項目配置“複製策略”,標明需要複製的項目以及鏡像。管理員在複製策略中指明目 ...


一 Harbor主從介紹

harbor官方預設提供主從複製的方案來解決鏡像同步問題,通過複製的方式,我們可以實時將測試環境harbor倉庫的鏡像同步到生產環境harbor,類似於如下流程: 97_thumb1

Harbor以“項目”為中心,通過對項目配置“複製策略”,標明需要複製的項目以及鏡像。管理員在複製策略中指明目標實例,即複製的“目的地”,並對它的地址和連接時使用的用戶名密碼進行設置。當複製策略被激活時,源項目下的所有鏡像,都會被覆制到目標實例;此外,當源項目下的鏡像被添加或刪除(push或delete), 只要策略還在激活狀態,鏡像的變化都會同步到目標實例上去, 如下圖所示:

98_thumb1 在實際生產運維的中,需要把鏡像發佈到幾十或上百台集群節點上。這時,單個Registry已經無法滿足大量節點的下載需求,因此要配置多個Registry實例做負載均衡。手工維護多個Registry實例上的鏡像,將是十分繁瑣的事情。Harbor可以支持一主多從的鏡像發佈模式,可以解決大規模鏡像分發與同步,架構如下: 99_thumb1

二 Harbor主從部署

2.1 前期準備

節點 IP地址 備註
docker01 172.24.8.111 Docker harbor主節點,reg.harbor01.com
docker02 172.24.8.112 Docker harbor從節點,reg.harbor02.com
docker03 172.24.8.113 Docker客戶端,用於測試倉庫
建議所有節點添加hosts解析:
  1 172.24.8.111 reg.harbor01.com
  2 172.24.8.112 reg.harbor02.com
 

2.1 主從節點部署Harbor

部署方法可參考《011.Docker倉庫管理》部署。 提示:主從節點都必須部署Harbor,本實驗採用http形式,只需要修改hostname為對應的功能變數名稱即可。 註意:Job services主要用於鏡像複製,本地鏡像可以被同步到遠程Harbor實例上。因此若採用功能變數名稱配置,則需要在jobservice的hosts中添加主從解析,為方便修改,可將使用以下腳本快速在所有容器hosts添加相應解析:
  1 root@docker02:~/harbor# cat addhosts.sh
  2 #!/bin/sh
  3 #****************************************************************#
  4 # ScriptName: test.sh
  5 # Author: [email protected]
  6 # Create Date: 2018-10-27 15:48
  7 # Modify Author: [email protected]
  8 #***************************************************************#
  9 docker ps | awk '{print $1}'>./dockerlist.txt
 10 for id in `cat ./dockerlist.txt`
 11 do
 12     HOSTS=`docker inspect $id | grep hosts | awk -F "\"" '{print $4}'`
 13     echo -e "172.24.8.111 reg.harbor01.com\n172.24.8.112 reg.harbor02.com" >> $HOSTS
 14 done
  在Harbor部署完畢後執行該腳本:chmod u+x addhosts.sh && bash addhosts.sh。

2.2 主節點測試

瀏覽器使用預設賬號和密碼Harbor12345訪問:http://reg.harbor01.com 100_thumb1

2.3 創建用於複製的測試項目

101_thumb1

2.4 倉庫管理新建從目標

102_thumb1

2.5 創建複製策略

103_thumb1

2.6 docker 客戶端測試

  1 root@docker03:~# vi /etc/hosts
  2 172.24.8.111 reg.harbor01.com
  3 172.24.8.112 reg.harbor02.com
  4 root@docker03:~# vi /etc/docker/daemon.json
  5 {
  6     "insecure-registries": ["http://reg.harbor01.com","http://reg.harbor02.com"]
  7 }
  8 root@docker03:~# systemctl daemon-reload
  9 root@docker03:~# systemctl restart docker.service
 10 root@docker03:~# docker login reg.harbor01.com		#登錄registry
 11 Username: admin
 12 Password:
  提示:公開的registry可pull,但push也必須登錄,私有的registry必須登錄才可pull和push。
  1 root@docker03:~# docker pull hello-world
  2 root@docker03:~# docker tag hello-world:latest reg.harbor01.com/copyregistry/hello-world:xhy
  3 root@docker03:~# docker push reg.harbor01.com/copyregistry/hello-world:xhy
  瀏覽器使用預設賬號和密碼Harbor12345訪問:http://reg.harbor01.com,查看是否同步狀態: 104_thumb1 瀏覽器使用預設賬號和密碼Harbor12345訪問:http://reg.harbor02.com,查看是否同步成功: 105_thumb1   參考鏈接:https://www.cnblogs.com/breezey/p/9444231.html 參考鏈接:https://blog.csdn.net/hiyun9/article/details/79655385
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MemCache memcache是一套分散式的高速緩存系統。目前被許多網站使用以提升網站的訪問速度,尤其對於一些大型的、需要頻繁訪問資料庫的網站訪問速度提升效果十分顯著,是一套開放源代碼軟體。 工作流程 MemCache的工作流程如下:先檢查客戶端的請求數據是否在memcached中,如有,直接把 ...
  • SQLite在本地存儲方面使用非常廣泛,項目中使用SQLite存儲客戶端消息記錄,本筆記記錄使用過程,同時分享一個常見的錯誤,希望能幫到他人。 ...
  • 在我們wpf開發中,很多人會有mvvm模式去做wpf的項目。 是否有人遇到這樣一個場景:在一個界面上,有個tabcontrol上面有4個頁簽,每個頁簽裡面都有一個datagrid,裡面顯示的列基本一樣,綁定的數據集合都是同一個,但是有個差異,在第二個頁簽上需要第二列不顯示,第三個頁簽只顯示一個列。 ...
  • 今天寫一個前端頁面,仿造千層網那種,用display:flex佈局遇到的幾個問題 首先是間隔問題,justify-content:space-between和space-around的區別 space-around我覺得就是會首尾留白 between就是首尾不留白,DIV之間的間隔更大 然後做一個類 ...
  • 現在很多網站都需要驗證身份證信息,但是我們有時候又擔心自己的身份證暴露在某些網站可能會給自己帶來不必要的麻煩,所以做了這個 身份證號碼生成器:https://www.atool8.com/tools/idgenerator(請誤用於非法用途) 另外引入了幾款第三方的工具,像PPT設計插件。後續也會持 ...
  • 一、消息隊列 消息即是信息的載體。為了讓消息發送者和消息接收者都能夠明白消息所承載的信息(消息發送者需要知道如何構造消息;消息接收者需要知道如何解析消息),它們就需要按照一種統一的格式描述消息,這種統一的格式稱之為消息協議。所以,有效的消息一定具有某一種格式;而沒有格式的消息是沒有意義的。而消息從發 ...
  • 一 Docker倉庫介紹 docker 倉庫,即 registry,實現了鏡像的管理、分發,同時還包括用戶的認證。docker registry 倉庫是一個無狀態的、高可靠的伺服器應用程式,用來存儲docker鏡像。docker.io 為 docker 官方的倉庫,預設所有的pull均是從官方倉庫拉 ...
  • 原創:https://www.cnblogs.com/bluestorm/p/5981435.html 系統啟動過程大致流程:上電-->BIOS自檢-->系統引導-->啟動內核-->初始化系統 BIOS自檢 BIOS 輸入輸出系統,它可以永久的記錄在ROM的一個軟體,是操作系統輸入輸出管理的一部分 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...