在前面的實驗中,咱們部署了多個副本的服務,本節將討論如何滾動更新每個副本。html
滾動更新下降了應用更新的風險,若是某個副本更新失敗,整個更新將暫停,其餘副本則能夠繼續提供服務。同時,在更新的過程當中,老是有副本在運行的,所以也保證了業務的連續性。node
下面咱們將部署三副本的服務,鏡像使用 httpd:2.2.31,而後將其更新到 httpd:2.2.32。web
建立服務:docker
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
指定新的鏡像。ui
Swarm 將按照以下步驟執行滾動更新:spa
中止第一個副本。code
調度任務,選擇 worker node。orm
在 worker 上用新的鏡像啓動副本。htm
若是副本(容器)運行成功,繼續更新下一個副本;若是失敗,暫停整個更新過程。
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