Docker容器編排

来源:https://www.cnblogs.com/wandaren/archive/2023/08/10/17621901.html
-Advertisement-
Play Games

# docker-compose ## compose安裝 ### Compose 簡介 Compose 是用於定義和運行多容器 Docker 應用程式的工具。通過 Compose,您可以使用 YML 文件來配置應用程式需要的所有服務。然後,使用一個命令,就可以從 YML 文件配置中創建並啟動所有服 ...


docker-compose

compose安裝

Compose 簡介

Compose 是用於定義和運行多容器 Docker 應用程式的工具。通過 Compose,您可以使用 YML 文件來配置應用程式需要的所有服務。然後,使用一個命令,就可以從 YML 文件配置中創建並啟動所有服務。
Compose 使用的三個步驟:

  • 使用 Dockerfile 定義應用程式的環境。
  • 使用 docker-compose.yml 定義構成應用程式的服務,這樣它們可以在隔離環境中一起運行。
  • 最後,執行 docker-compose up 命令來啟動並運行整個應用程式。

Linux 上我們可以從 Github 上下載它的二進位包來使用,最新發行的版本地址。運行以下命令以下載 Docker Compose 的當前穩定版本:

curl -L "https://github.com/docker/compose/releases/download/v2.20.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

要安裝其他版本的 Compose,請替換 v2.20.2。
將可執行許可權應用於二進位文件:

sudo chmod +x /usr/local/bin/docker-compose

創建軟鏈:

sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

測試是否安裝成功:

docker-compose version

image.png

nginx示例

docker-compose.yml配置案例如下,官方文檔

version: "3.8"
services:
  nginx-demo:
    image: nginx
    restart: always
    networks:
      - network_test
    volumes:
      - /Users/wandaren/develop/docker-nginx/conf/nginx.conf:/etc/nginx/nginx.conf
      - /Users/wandaren/develop/docker-nginx/log:/var/log/nginx
      - /Users/wandaren/develop/docker-nginx/html:/usr/share/nginx/html
    environment:
      APP_ENV: dev
    dns: 114.114.115.115
    ports: 
      - 80

networks:
  network_test:
    driver: bridge
    ipam:
      driver: default
      config:
        - subnet: 188.18.0.0/16

啟動:

# 創建
docker-compose create nginx-demo
# 載入配置並啟動
docker-compose up -d nginx-demo
# 重新讀取配置內容
docker-compose up -d
# 啟動
docker-compose start nginx-demo
# 停止
docker-compose stop nginx-demo
# 停止並刪除
docker-compose down nginx-demo

image.png
動態擴容

docker-compose up -d --scale nginx-demo=2

image.png

Swarm(分散式)

簡介

Docker Swarm 是 Docker 的集群管理工具。它將 Docker 主機池轉變為單個虛擬 Docker 主機。 Docker Swarm 提供了標準的 Docker API,所有任何已經與 Docker 守護程式通信的工具都可以使用 Swarm 輕鬆地擴展到多個主機。
支持的工具包括但不限於以下各項:

  • Dokku
  • Docker Compose
  • Docker Machine
  • Jenkins

原理

如下圖所示,swarm 集群由管理節點(manager)和工作節點(work node)構成。

  • swarm mananger:負責整個集群的管理工作包括集群配置、服務管理等所有跟集群有關的工作。
  • work node:即圖中的 available node,主要負責運行相應的服務來執行任務(task)。

image.png

使用

1、創建 swarm 集群管理節點(manager)

初始化 swarm 集群,進行初始化的這台機器,就是集群的管理節點。

# 172.16.156.158為虛擬機本機ip
docker swarm init --advertise-addr 172.16.156.158

image.png
以上輸出,證明已經初始化成功。需要把以下這行複製出來,在增加工作節點時會用到:

docker swarm join --token SWMTKN-1-4dq96unmcsz9v0m99vapdtegt5y0kym3ths69r6enlgofbgja7-7ml2skxa3y5x5cjly8uxfwoae 172.16.156.158:2377

2、創建 swarm 集群工作節點(worker)

分別進入兩個機器里,指定添加至上一步中創建的集群,這裡會用到上一步複製的內容。
image.png
image.png

3、查看集群信息

進入管理節點,執行:docker info 可以查看當前集群的信息。

docker info

image.png
通過畫紅圈的地方,可以知道當前運行的集群中,有三個節點,其中有一個是管理節點。
進入管理節點,執行:docker node ls 查看集群信息:

docker node ls

image.png

4、部署服務到集群中

註意:跟集群管理有關的任何操作,都是在管理節點上操作的。
以下例子,在一個工作節點上創建一個名為 nginx_swarm 的nginx服務,這裡是隨機指派給一個工作節點:

docker service create --replicas 1 -p 80:80 --name nginx_swarm nginx

image.png
image.png

5、查看服務部署情況

查看 nginx_swarm 服務運行在哪個節點上,可以看到目前是在 wq 節點:

docker service ps nginx_swarm

image.png
查看 nginx_swarm 部署的具體信息:

docker service inspect --pretty nginx_swarm

image.png

6、擴展集群服務

調整節點個數

# docker service update --replicas <num> <service id/name>
docker service update --replicas 2 nginx_swarm

image.png
服務擴展

docker service scale nginx_swarm=3

image.png

7、滾動升級服務

以下實例,我們將介紹 redis 版本如何滾動升級至更高版本。
創建一個 3.0.6 版本的 redis。

docker service create --replicas 1 --name redis --update-delay 10s redis:3.0.6

滾動升級 redis

docker service update --image redis:3.0.7 redis

image.png

8、刪除服務

docker service rm nginx_swarm

image.png

9、停止某個節點接收新的任務

停止節點001

docker node update --availability drain 001

image.png
註意:001 狀態變為 Drain。不會影響到集群的服務,只是 001 節點不再接收新的任務,集群的負載能力有所下降。
可以通過以下命令重新激活節點:

docker node update --availability active 001

image.png

10、節點退出集群

docker swarm leave

image.png
image.png
刪除退出集群的節點

docker node rm sysn25urcm4elywoiexiov431

image.png


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

-Advertisement-
Play Games
更多相關文章
  • # 前言 提到爬蟲可能大多都會想到python,其實爬蟲的實現並不限制任何語言。 下麵我們就使用js來實現,後端為express,前端為vue3。 # 實現功能 話不多說,先看結果: ![image](https://img2023.cnblogs.com/blog/1769804/202308/1 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 最近,我剛剛完成了一個閱讀器的txt文件閱讀功能,但在處理大文件時,遇到了文本內容過多導致瀏覽器崩潰的問題。 一般情況下,沒有任何樣式渲染時不會出現什麼問題,15MB的文件大約會有3秒的空白時間。 <div id="content"></ ...
  • ## css3 瀑布流佈局遇見截斷下一列展示後半截現象 - 註:css3實現瀑布流佈局簡直不要太香~~~~~ ## 場景-在uniapp項目中 ### 當瀑布流佈局column-grap:10px 相鄰兩列之間的間隙為10px,column-count:2,2列展示時,就出現了截斷問題,如下圖: ! ...
  • 7月27號下午2點 New 操作符做了什麼: 1. 創建一個新的空對象。 2. 將這個新對象的原型指向構造函數的原型。 3. 將構造函數的this指向這個新對象。 4. 根據構造函數返回類型作判斷,如果是值類型,返回newObj。如果是引用類型,就返回這個引用類型的對象 Vue2 數組push、sh ...
  • # CSS 選擇器權重 聲明:本文參考來源於[MDN CSS 優先順序](https://developer.mozilla.org/zh-CN/docs/Web/CSS/Specificity)(80%)和B站尚矽谷的[課程](https://m.bilibili.com/video/BV1p84y ...
  • 當我們疲於開發一個接一個的需求時,很容易忘記去關註網站的性能,到了某一個節點,猛地發現,隨著越來越多代碼的堆積,網站變得越來越慢。本文就是從這樣的一個背景出發,著手優化網站的前端性能,並總結出一套開發習慣,讓我們在日常開發時,也保持高性能,而不是又一次回過頭來優化性能。 ...
  • 隨著大屏幕技術的發展,大屏數字滾動效果在各種應用場景中越來越常見,例如數字展示、統計數據展示等。Vue3 作為一種流行的前端開發框架,提供了強大的工具和便捷的開發方式,非常適合實現大屏數字滾動效果。 本篇博文將介紹如何使用 Vue3 來實現大屏數字滾動效果。在實現過程中,我們可以使用調試工具進行測... ...
  • 通過編碼實戰瞭解quarkus攔截器的另一個高級特性:禁用類級別攔截器,這樣可以避免類級別和方法級別攔截器的疊加衝突 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...