今天就跟大家聊聊有關如何滾動更新Service,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據(jù)這篇文章可以有所收獲。
目前創(chuàng)新互聯(lián)已為千余家的企業(yè)提供了網(wǎng)站建設、域名、雅安服務器托管、網(wǎng)站托管運營、企業(yè)網(wǎng)站設計、昭平網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
在前面的實驗中,我們部署了多個副本的服務,本節(jié)將討論如何滾動更新每一個副本。
滾動更新降低了應用更新的風險,如果某個副本更新失敗,整個更新將暫停,其他副本則可以繼續(xù)提供服務。同時,在更新的過程中,總是有副本在運行的,因此也保證了業(yè)務的連續(xù)性。
下面我們將部署三副本的服務,鏡像使用 httpd:2.2.31,然后將其更新到 httpd:2.2.32。
創(chuàng)建服務:
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 將按照如下步驟執(zhí)行滾動更新:
停止第一個副本。
調度任務,選擇 worker node。
在 worker 上用新的鏡像啟動副本。
如果副本(容器)運行成功,繼續(xù)更新下一個副本;如果失敗,暫停整個更新過程。
docker service ps
查看更新結果。
三個副本都已經(jīng)更新到 httpd:2.2.32。
默認配置下,Swarm 一次只更新一個副本,并且兩個副本之間沒有等待時間。我們可以通過 --update-parallelism
設置并行更新的副本數(shù)目,通過 --update-delay
指定滾動更新的間隔時間。
比如執(zhí)行如下命令:
docker service update --replicas 6 --update-parallelism 2 --update-delay 1m30s my_web
service 增加到六個副本,每次更新兩個副本,間隔時間一分半鐘。
docker service inspect
查看 service 的當前配置。
docker service ps
確保6個副本處于正常狀態(tài)。
執(zhí)行如下命令,將鏡像更新到 httpd:2.4.16。
docker service update --image httpd:2.4.16 my_web
等待一會,查看更新的狀態(tài)。
有4個副本已經(jīng)更新到 httpd:2.4.16,從啟動時間看,確實是分了兩批進行,之間間隔90秒,每次更新兩個副本。
Swarm 還有個方便的功能是回滾,如果更新后效果不理想,可以通過 --rollback
快速恢復到更新之前的狀態(tài)。
service 所有副本都已經(jīng)恢復到 httpd:2.2.32。
請注意,--rollback
只能回滾到上一次執(zhí)行 docker service update
之前的狀態(tài),并不能無限制地回滾。
看完上述內容,你們對如何滾動更新Service有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。