1. 程式人生 > >如何滾動更新 Service?- 每天5分鐘玩轉 Docker 容器技術(102)

如何滾動更新 Service?- 每天5分鐘玩轉 Docker 容器技術(102)

docker容器教程swarm

在前面的實驗中,我們部署了多個副本的服務,本節將討論如何滾動更新每一個副本。

滾動更新降低了應用更新的風險,如果某個副本更新失敗,整個更新將暫停,其他副本則可以繼續提供服務。同時,在更新的過程中,總是有副本在運行的,因此也保證了業務的連續性。

下面我們將部署三副本的服務,鏡像使用 httpd:2.2.31,然後將其更新到 httpd:2.2.32。

創建服務:

docker service create --name my_web --replicas=3 httpd:2.2.31

技術分享圖片

將 service 更新到 httpd:2.2.32:

docker service update --image httpd:2.2.32 my_web

--image 指定新的鏡像。

Swarm 將按照如下步驟執行滾動更新:

  1. 停止第一個副本。

  2. 調度任務,選擇 worker node。

  3. 在 worker 上用新的鏡像啟動副本。

  4. 如果副本(容器)運行成功,繼續更新下一個副本;如果失敗,暫停整個更新過程。

docker service ps 查看更新結果。

技術分享圖片

三個副本都已經更新到 httpd:2.2.32。

默認配置下,Swarm 一次只更新一個副本,並且兩個副本之間沒有等待時間。我們可以通過 --update-parallelism 設置並行更新的副本數目,通過 --update-delay 指定滾動更新的間隔時間。

比如執行如下命令:

docker service update --replicas 6 --update-parallelism 2 --update-delay 1m30s my_web

service 增加到六個副本,每次更新兩個副本,間隔時間一分半鐘。

docker service inspect 查看 service 的當前配置。

技術分享圖片

docker service ps 確保6個副本處於正常狀態。

技術分享圖片

執行如下命令,將鏡像更新到 httpd:2.4.16。

docker service update --image httpd:2.4.16 my_web

等待一會,查看更新的狀態。

技術分享圖片

有4個副本已經更新到 httpd:2.4.16,從啟動時間看,確實是分了兩批進行,之間間隔90秒,每次更新兩個副本。

Swarm 還有個方便的功能是回滾,如果更新後效果不理想,可以通過 --rollback 快速恢復到更新之前的狀態。

技術分享圖片

service 所有副本都已經恢復到 httpd:2.2.32。

請註意,--rollback 只能回滾到上一次執行 docker service update 之前的狀態,並不能無限制地回滾。

滾動更新就討論到這裏,下一節我們學習 Docker Swarm 如何管理數據。

技術分享圖片書籍:

1.《每天5分鐘玩轉Docker容器技術》
https://item.jd.com/16936307278.html

2.《每天5分鐘玩轉OpenStack》
https://item.jd.com/12086376.html

技術分享圖片

如何滾動更新 Service?- 每天5分鐘玩轉 Docker 容器技術(102)