如何滾動更新Service

今天就跟大家聊聊有關(guān)如何滾動更新Service,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

目前創(chuàng)新互聯(lián)已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管運(yùn)營、企業(yè)網(wǎng)站設(shè)計、昭平網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

在前面的實(shí)驗(yàn)中,我們部署了多個副本的服務(wù),本節(jié)將討論如何滾動更新每一個副本。

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

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

創(chuàng)建服務(wù):

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í)行滾動更新:

  1. 停止第一個副本。

  2. 調(diào)度任務(wù),選擇 worker node。

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

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

docker service ps 查看更新結(jié)果。

三個副本都已經(jīng)更新到 httpd:2.2.32。

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

比如執(zhí)行如下命令:

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

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

docker service inspect 查看 service 的當(dāng)前配置。

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,從啟動時間看,確實(shí)是分了兩批進(jìn)行,之間間隔90秒,每次更新兩個副本。

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

service 所有副本都已經(jīng)恢復(fù)到 httpd:2.2.32。

請注意,--rollback 只能回滾到上一次執(zhí)行 docker service update 之前的狀態(tài),并不能無限制地回滾。

看完上述內(nèi)容,你們對如何滾動更新Service有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

分享文章:如何滾動更新Service
網(wǎng)站網(wǎng)址:http://muchs.cn/article42/jpjcec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供域名注冊、定制網(wǎng)站、搜索引擎優(yōu)化、手機(jī)網(wǎng)站建設(shè)、面包屑導(dǎo)航、App設(shè)計

廣告

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

成都app開發(fā)公司