bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

DockerSwarm群集配置實戰(2)-創新互聯

前言:

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:域名注冊、網絡空間、營銷軟件、網站建設、青原網站維護、網站推廣。

這篇博文是基于docker Swarm群集環境之上,延伸了Docker Swarm的功能。

博文大綱:
一、Docker Swarm網絡管理
二、Swarm的service管理及版本更新

這篇博文的環境還是基于上一篇博文中搭建的環境,具體可以參考博文:Docker Swarm群集配置實戰(1) ,在進行接下來的操作之前,必須要保證訪問docker Swarm的web UI時,可以看到以下界面:

Docker Swarm群集配置實戰(2)

一、Docker Swarm網絡管理

Swarm群集會產生兩種不同類型的流量:

  • 控制和管理層面:包括 Swarm 消息管理等,例如請求加入或離開Swarm,這種類型的流量總是被加密的。(涉及到集群內部的hostname、ip-address、subnet、gateway等);
  • 應用數據層面:包括容器與客戶端的通信等。(涉及到防火墻、端口映射、網口映射、VIP等)

在Swarm service中有三個重要的網絡概念:

  • overlay networks 管理Swarm中docker守護進程間的通信。可以將容器附加到一個或多個已存在的overlay網絡上,使容器與容器之間能夠通信;
  • ingress network 是一個特殊的 overlay 網絡,用于服務節點間的負載均衡。當任何 Swarm 節點在發布的端口上接收到請求時,它將該請求交給一個名為 IPVS 的模塊。IPVS 跟蹤參與該服務的所有IP地址,選擇其中的一個,并通過 ingress 網絡將請求路由到它;
    初始化或加入 Swarm 集群時會自動創建 ingress 網絡,大多數情況下,用戶不需要自定義配置,但是 docker 17.05 和更高版本允許你自定義。
  • docker_gwbridge是一種橋接網絡,將 overlay 網絡(包括 ingress 網絡)連接到一個單獨的 Docker 守護進程的物理網絡。默認情況下,服務正在運行的每個容器都連接到本地 Docker 守護進程主機的 docker_gwbridge 網絡。
    docker_gwbridge 網絡在初始化或加入 Swarm 時自動創建。大多數情況下,用戶不需要自定義配置,但是 Docker 允許自定義。

查看docker01上面的默認網絡,如下(注意其SCOPE列,確認其生效范圍):

Docker Swarm群集配置實戰(2)

除了Swarm群集默認創建的兩個網絡以外,我們還可以自定義創建overlay網絡,連接到此網絡的容器,即可互相通信,但是需要注意,除了在docker01這個manager上可以查看創建的overlay網絡外,其他節點在沒有加入此網絡前,執行“docker network ls”命令是查看不到的。

創建自定義overlay網絡并驗證

[root@docker01 ~]# docker network create -d overlay --subnet 192.168.22.0/24 --gateway 192.168.22.1 --attachable my_net1
# 創建一個overlay網絡,名字為my_net1;
# “--subnet”:指定其網段(可以不指定);“--gateway”:指定其網關(可以不指定);
# 但是在docker  Swarm群集中創建overlay網絡時,必須添加“--attachable”選項
# 否則,其他節點的容器運行時,無法使用此網絡

創建完成后,在其他docker節點上是查看不到這個新創建的overlay網絡的,但是,可以使用此網絡(在運行容器時,直接指定即可,等容器運行后,便可以查看到此網絡了)
Docker Swarm群集配置實戰(2)

測試剛剛創建的overlay網絡,是否可用,分別在docker01、docker02上基于創建的overlay網絡運行一個容器,然后進行ping測試,確認可以ping通:

#docker01主機上基于overlay網絡創建一個容器:
[root@docker01 ~]# docker run -tid --network my_net1 --name test1 busybox
#同docker01的操作,在docker02上也創建一個:
[root@docker02 ~]# docker run -tid --network my_net1 --name test2 busybox

在容器創建后,在docker02主機上,使用test2這個容器去ping容器test1,測試結果如下(由于是自定義網絡,所以可以直接ping對端容器的容器名):

Docker Swarm群集配置實戰(2)

二、Swarm的service管理及版本更新

1、指定某個service運行在同一臺docker服務器上

在第一篇的博文中測試過,如果Swarm群集中的manager下發一個service任務,那么,下發的任務將隨機分布在群集中的docker服務器之上運行, 如果說,由于需要將自己的生產環境配置的統一、規范一些,某一臺docker服務器,我就只運行web服務,另一臺docker主機,我就只運行PHP服務,那么,怎么解決呢?

解決方案一:

[root@docker01 ~]# docker service create --replicas 3 --constraint node.hostname==docker03 --name test nginx
#在docker03主機上,基于nginx鏡像,運行3個名為test的容器

上述命令的執行后如下所示:

Docker Swarm群集配置實戰(2)

解決方案二:

[root@docker01 ~]# docker node update --label-add mem=max docker02
#以鍵值對的方式給docker02主機打上標簽“mem=max”,等號兩邊的內容是可以自定義的
[root@docker01 ~]# docker service create --name test01 --replicas 3 --constraint 'node.labels.mem==max' nginx
#基于nginx鏡像在標簽為“mem==max”的主機上運行3個名為test01的服務
[root@docker01 ~]# docker node inspect docker02   #可以執行此命令查看dokcer02主機的標簽
#標簽相關的信息,在Spec{  }中

查看web UI界面進行確認:

Docker Swarm群集配置實戰(2)

2、更新某個service版本

1)準備要使用的鏡像,并基于此鏡像運行service
[root@docker01 aa]# cat html/index.html    #準備網頁文件
127.0.0.1
[root@docker01 aa]# cat Dockerfile      
#基于nginx容器,將當前目錄下的html目錄掛載為nginx的網頁根目錄
FROM nginx
ADD html /usr/share/nginx/html
[root@docker01 aa]# docker build -t 192.168.20.6:5000/testnginx:1.0 .     #生成一個鏡像
[root@docker01 aa]# docker push 192.168.20.6:5000/testnginx:1.0
#將新生成的鏡像上傳至私有倉庫
[root@docker01 aa]# docker service create --name newnginx -p 80:80 --replicas 3  192.168.20.6:5000/testnginx:1.0 
#基于上傳到私有倉庫的鏡像,運行三個service,并映射到本地80端口
#當上面的命令執行成功后,只要docker主機上運行著那個service,就可以通過它的80端口訪問到nginx服務

運行后,web UI界面顯示如下:

Docker Swarm群集配置實戰(2)

可以看到,每個節點都運行了那個service,也就是說,訪問哪個節點的80端口,都可以看到一樣的頁面,如下:

Docker Swarm群集配置實戰(2)

Docker Swarm群集配置實戰(2)

在docker01上查看service的詳細信息,如下:

[root@docker01 aa]# docker service ps newnginx    #查看service的詳細信息

命令執行的結果(需要注意的是其鏡像標簽,也就是說注意其是基于哪個鏡像運行的):
Docker Swarm群集配置實戰(2)

2)準備該鏡像的2.0版本(模擬在線版本升級):

[root@docker01 aa]# docker tag nginx:latest 192.168.20.6:5000/testnginx:2.0 
#準備2.0版本的鏡像
[root@docker01 aa]# docker push 192.168.20.6:5000/testnginx:2.0 
#上傳到私有倉庫
[root@docker01 aa]# docker service update --image 192.168.20.6:5000/testnginx:2.0 newnginx 
#將newnginx服務的鏡像升級到2.0
[root@docker01 aa]# docker service ps newnginx    #再次查看service的詳細信息

命令執行的結果如下,發現基于1.0鏡像運行的newnginx的service狀態已經變成了shutdown,而基于2.0運行的service變為了running,如下:

Docker Swarm群集配置實戰(2)

此時,若再次訪問其web頁面,就變為了nginx的默認首頁(因為我們的2.0鏡像只是更改了下nginx鏡像的標簽,并沒有修改其文件),如下:

Docker Swarm群集配置實戰(2)

其web UI界面可以查看到該service的最后一次升級的時間。

3)升級2.0到3.0(升級時,對其進行精細的控制)

[root@docker01 aa]# docker tag nginx:latest 192.168.20.6:5000/testnginx:3.0 
#準備3.0版本的鏡像
[root@docker01 aa]# docker push 192.168.20.6:5000/testnginx:3.0 
#上傳到私有倉庫
[root@docker01 ~]# docker service update --replicas 6 --image 192.168.20.6:5000/testnginx:3.0 --update-parallelism 3 --update-delay 1m newnginx
#上述選項的含義如下:
# “--replicas 6”:更新后的service數量為6個(原本是3個)
# “ --update-parallelism 2 ”:設置并行更新的副本數。
# “ --update-delay 1m ”:指定滾動更新的時間間隔為1分鐘
[root@docker01 ~]# docker service ps newnginx    #自行對比newnginx服務的詳細信息

4)版本回滾操作

當我們升級到新的版本后,發現新版本的鏡像有些問題,而不得不返回之前運行的版本,那么可以執行下面的操作:

[root@docker01 ~]# docker service update --rollback newnginx   #將newnginx的service回滾到前一個版本
[root@docker01 ~]# docker service ps newnginx   #自行查看

執行回滾命令后,回滾過程如下:

Docker Swarm群集配置實戰(2)

回滾成功后,我這里就從原來的3.0變回了2.0,雖然在升級3.0的時候,指定的service數量是6個,但是之前只有3個,所以在執行回滾操作后,service數量也將變回3個。

注意:當我們執行回滾操作的時候,默認是回滾到上一次操作的版本,并且不可以連續回滾。

———————— 本文至此結束,感謝閱讀 ————————

另外有需要云服務器可以了解下創新互聯cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網站標題:DockerSwarm群集配置實戰(2)-創新互聯
網頁URL:http://vcdvsql.cn/article28/csidcp.html

成都網站建設公司_創新互聯,為您提供網站改版搜索引擎優化小程序開發定制網站企業網站制作網站維護

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

搜索引擎優化