容器編排工具鑒賞- docker-compose 、Kubernetes、OpenShift、Docker Swarm

来源:https://www.cnblogs.com/jiagooushi/archive/2022/09/02/16650060.html
-Advertisement-
Play Games

任務編排工具 我們發現我們現在管理微服務比較麻煩,現在只是三個微服務,如果更多會更加麻煩,怎麼辦呢,下麵我們就來學習下docker編排工具 什麼是任務編排 編排是一個新的辭彙,經過閱讀才明白編排指的是容器的集群化和調度。另一類含義指的是容器管理,負責管理容器化應用和組件任務。 ​ docker毫無疑 ...


任務編排工具

我們發現我們現在管理微服務比較麻煩,現在只是三個微服務,如果更多會更加麻煩,怎麼辦呢,下麵我們就來學習下docker編排工具

什麼是任務編排

編排是一個新的辭彙,經過閱讀才明白編排指的是容器的集群化和調度。另一類含義指的是容器管理,負責管理容器化應用和組件任務。

​ docker毫無疑問是一個優秀的開源工具。但是,僅靠docker引擎和容器就不能進行複雜的應用程式部署。對於部署複雜的應用程式體繫結構的容器群集,必須進行適當的配置。容器化的應用程式應該能夠根據應用程式資源需求進行擴展和縮小。

需要考慮的因素

我們需要一個有效管理容器的良好框架。容器的生命周期很短,在進行容器編排時,要考慮的主要因素是

  1. 聯網
  2. 高可用性
  3. 易於部署
  4. 良好的服務發現。

常見的任務編排工具

docker-compose

file

​ docker-compose是基於docker的編排工具,使容器的操作能夠批量的,可視的執行,是一個管理多個容器的工具,比如可以解決容器之間的依賴關係,當在宿主機啟動較多的容器時候,如果都是手動操作會覺得比較麻煩而且容器出錯,這個時候推薦使用 dockerd的單機編排工具 docker-compose。

Kubernetes

file

​ Kubernetes是一個開源的,開箱即用的容器集群管理器和業務流程。它具有出色的構建 調度器 和資源管理器,用於以更有效和高度可用的方式部署容器。Kubernetes已成為許多組織事實上的容器編排工具。kubernetes項目由google與世界各地的貢獻者維護。它提供了本機Docker工具不提供的許多功能。而且,使用kubernetes很容易上手。

OpenShift

file

​ Openshift建立在kubernetes之上。Openshift項目由Redhat維護。它同時具有開源(openshift orgin)和企業版(openshift容器平臺)。連同核心的Kubernetes功能,它提供了用於容器管理和編排的開箱即用組件。

Docker Swarm

file

​ Docker生態系統包括從開發到生產部署框架的工具。在該列表中,docker swarm適用於集群管理。可以使用docker-compose,swarm,overlay網路和良好的服務發現工具(例如etcd或consul)的組合來管理Docker容器集群。

​ 與其他開源容器集群管理工具相比,Docker swarm在功能方面仍日趨成熟。考慮到龐大的Docker貢獻者,Docker swarm擁有其他工具擁有的所有最佳功能不會太久。Docker記錄了在生產中使用docker swarm 的良好生產計劃。

環境準備

我們這裡面主要講解docker-composeswarm的編排工具

搭建Horbor倉庫

我們剛纔講解了本地搭建Horbor倉庫,但是我們本地搭建很占用資源,我們用了一臺伺服器專門來做Horbor的倉庫,地址是https://manager-hongbaoyu-java.itheima.net:8443/

file

停止本地Harbor

因為使用了單獨的Harbor伺服器,本地的Harbor就可以停掉了

 cd /usr/local/harbor/harbor/ && docker-compose down

file

清理Docker環境
清理本地環境

因為使用任務編排,本地的服務都可以刪除掉了

# 停止並刪除所有容器
docker rm -f $(sudo docker ps -a -q)
# 刪除所有鏡像
docker rmi $(docker images -q)

file

查看本地環境

可以查看下本地的Docker環境

docker ps -a
docker images

file

刪除網路配置

因為我們自己配置了Docker網路,我們刪除掉

docker network rm learn-docker-network

file

修改Docker配置

因為我們使用了獨立的Horbor倉庫,可以將配置到Docker中的本地倉庫地址替換為新的倉庫地址

修改daemon
# 修改daemon文件刪除本地倉庫地址
vi /etc/docker/daemon.json

daemon.json中增加如下內容

"insecure-registries": ["manager-hongbaoyu-java.itheima.net:8443"],
查看修改
# 查看daemon配置
cat /etc/docker/daemon.json

新的倉庫地址是manager-hongbaoyu-java.itheima.net:8443

file

重啟Docker
systemctl daemon-reload
service docker restart
初始化鏡像

將伺服器的需要的鏡像初始化

docker pull mysql:5.7.33;\
docker pull nacos/nacos-server;\
docker pull manager-hongbaoyu-java.itheima.net:8443/library/learn-docker-web:1.0-SNAPSHOT;\
docker pull manager-hongbaoyu-java.itheima.net:8443/library/learn-docker-gateway:1.0-SNAPSHOT;\
docker pull manager-hongbaoyu-java.itheima.net:8443/library/learn-docker-storage:1.0-SNAPSHOT

本文由傳智教育博學谷教研團隊發佈。

如果本文對您有幫助,歡迎關註點贊;如果您有任何建議也可留言評論私信,您的支持是我堅持創作的動力。

轉載請註明出處!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 資料庫說明文檔,在我們開發項目時是非常必要的,有時項目交付時,客戶也是需要讓我們提供的,而如果人工編寫,比如耗時,通過screw組件來生成文檔,非常方便。 源代碼和使用:https://github.com/pig-mesh/screw 添加依賴 <dependency> <groupId>cn.s ...
  • 《Python灰帽子》PDF高清版免費下載地址(點擊即可) 內容簡介 · · · · · · 《Python灰帽子》是由知名安全機構Immunity Inc的資深黑帽Justin Seitz主筆撰寫的一本關於編程語言Python如何被廣泛應用於黑客與逆向工程領域的書籍。老牌黑客,同時也是Immuni ...
  • 前言 😋 大家早好、午好、晚好吖~ 開發環境: 解釋器版本: python 3.8 代碼編輯器: pycharm 2021.2 requests: pip install requests pandas: pip install pandas pyecharts: pip install pyec ...
  • 摘要:本文主要講解灰度線性變換,基礎性知識希望對您有所幫助。 本文分享自華為雲社區《[Python圖像處理] 十六.圖像的灰度非線性變換之對數變換、伽馬變換》,作者:eastmount 。 本篇文章主要講解非線性變換,使用自定義方法對圖像進行灰度化處理,包括對數變換和伽馬變換。 一.圖像灰度非線性變 ...
  • 大家好,我是不才陳某~ RPC、gRPC、Thrift、HTTP,大家知道它們之間的聯繫和區別麽?這些都是面試常考的問題,今天帶大家先搞懂 RPC 和 gRPC。 在講述 gRPC 之前,我們需要先搞懂什麼是 RPC。 不 BB,直接上文章目錄: 什麼是 RPC ? RPC(Remote Proce ...
  • 一、如果是使用 Qt Designer設計界面的話,那麼如何將Qt Designer設計出來的界面(.ui 文件)與業務邏輯程式接合起來,如下兩個方法:方法一:將.ui 文件通過命令轉換成 .py文件,然後在業務邏輯代碼中進行import xxxx導入即可 1、進入 .ui文件所在目錄,然後用命令: ...
  • 蘋果發佈Xcode 7之後,可以打開正常的AppleID或實機上傳,而不是$ 99或$ 299,只要你可以在AppStore下載應用程式的AppleID。關於Mac系統和Xcode的安裝,如果不請參見原文描述,這裡只介紹使用Xcode7和普通AppID創建免費證書、個人資料。 文中測試環境是OSX ...
  • parallelStream 一定更快嗎? 大家都知道 Stream 分為順序流和並行流: stream(順序流) parallelStream(並行流) 它們最大的區別就是 parallelStream 支持並行化處理,所以效率較 stream(順序流)肯定是要更快的。這篇不會介紹 Stream ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...