日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

k8s滚动更新(六)--技术流ken

發布時間:2024/3/12 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 k8s滚动更新(六)--技术流ken 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

實踐

?

滾動更新是一次只更新一小部分副本,成功后,再更新更多的副本,最終完成所有副本的更新。滾動更新的最大的好處是零停機,整個更新過程始終有副本在運行,從而保證了業務的連續性。

?

下面我們部署三副本應用,初始鏡像為 httpd:2.2.31,然后將其更新到 httpd:2.2.32。

?

第一步: httpd:2.2.31 的配置文件如下:

[root@ken ~]# cat httpd.yml apiVersion: apps/v1beta1 kind: Deployment metadata:name: httpd spec:replicas: 3template:metadata:labels:run: httpdspec:containers:- name: httpdimage: httpd:2.2.31ports:- containerPort: 80

?

第二步:部署應用并查看

[root@ken ~]# kubectl apply -f httpd.yml deployment.apps/httpd created[root@ken ~]# kubectl get deployment -o wide NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR httpd 0/3 3 0 10s httpd httpd:2.2.31 run=httpd

[root@ken ~]# kubectl get replicaset -o wide
NAME DESIRED CURRENT READY AGE CONTAINERS IMAGES SELECTOR
httpd-76cfb94bf4 3 3 0 23s httpd httpd:2.2.31 pod-template-hash=76cfb94bf4,run=httpd

[root@ken ~]# kubectl get pod -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES httpd-76cfb94bf4-629s2 1/1 Running 0 113s 10.244.1.34 host1 <none> <none> httpd-76cfb94bf4-lt9wb 1/1 Running 0 113s 10.244.1.33 host1 <none> <none> httpd-76cfb94bf4-n62nj 1/1 Running 0 113s 10.244.2.23 host2 <none> <none>

?

部署過程如下:

?

創建 Deployment httpd

創建 ReplicaSet?httpd-76cfb94bf4

創建三個 Pod

當前鏡像為 httpd:2.2.31

?

第三步:將配置文件中 httpd:2.2.31 替換為 httpd:2.2.32,再次執行 kubectl apply。

[root@ken ~]# kubectl apply -f httpd.yml deployment.apps/httpd configured[root@ken ~]# kubectl get deployment -o wide NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR httpd 3/3 1 3 4m2s httpd httpd:2.2.32 run=httpd[root@ken ~]# kubectl get replicaset -o wide #這一步要稍等幾分鐘才會切換到32版本 NAME DESIRED CURRENT READY AGE CONTAINERS IMAGES SELECTOR httpd-6cf6bf9f57 3 3 3 2m47s httpd httpd:2.2.32 pod-template-hash=6cf6bf9f57,run=httpd httpd-76cfb94bf4 0 0 0 6m30s httpd httpd:2.2.31 pod-template-hash=76cfb94bf4,run=httpd[root@ken ~]# kubectl get pod -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES httpd-6cf6bf9f57-5md94 1/1 Running 0 2m58s 10.244.2.24 host2 <none> <none> httpd-6cf6bf9f57-nvxnc 1/1 Running 0 75s 10.244.1.35 host1 <none> <none> httpd-6cf6bf9f57-v7lpg 1/1 Running 0 22s 10.244.1.36 host1 <none> <none>

我們發現了如下變化:

?

Deployment httpd 的鏡像更新為 httpd:2.2.32

新創建了 ReplicaSethttpd-6cf6bf9f57,鏡像為 httpd:2.2.32,并且管理了三個新的 Pod。

之前的 ReplicaSet?httpd-76cfb94bf4里面已經沒有任何 Pod。

結論是:ReplicaSethttpd-76cfb94bf4的三個 httpd:2.2.31 Pod 已經被 ReplicaSethttpd-6cf6bf9f57的三個 httpd:2.2.32 Pod 替換了。

?

第四步:具體過程可以通過 kubectl describe deployment httpd 查看。

[root@ken ~]# kubectl describe deployment httpd ... Events:Type Reason Age From Message---- ------ ---- ---- -------Normal ScalingReplicaSet 9m11s deployment-controller Scaled up replica set httpd-76cfb94bf4 to 3Normal ScalingReplicaSet 5m28s deployment-controller Scaled up replica set httpd-6cf6bf9f57 to 1Normal ScalingReplicaSet 3m45s deployment-controller Scaled down replica set httpd-76cfb94bf4 to 2Normal ScalingReplicaSet 3m45s deployment-controller Scaled up replica set httpd-6cf6bf9f57 to 2Normal ScalingReplicaSet 2m52s deployment-controller Scaled down replica set httpd-76cfb94bf4 to 1Normal ScalingReplicaSet 2m52s deployment-controller Scaled up replica set httpd-6cf6bf9f57 to 3Normal ScalingReplicaSet 2m50s deployment-controller Scaled down replica set httpd-76cfb94bf4 to 0

每次只更新替換一個 Pod:

?

ReplicaSet?httpd-6cf6bf9f57?增加一個 Pod,總數為 1

ReplicaSet?httpd-76cfb94bf4?減少一個 Pod,總數為 2

ReplicaSet?httpd-6cf6bf9f57?增加一個 Pod,總數為 2

ReplicaSet httpd-76cfb94bf4?減少一個 Pod,總數為 1

ReplicaSet?httpd-6cf6bf9f57?增加一個 Pod,總數為 3

ReplicaSet?httpd-76cfb94bf4?減少一個 Pod,總數為 0

?

每次替換的 Pod 數量是可以定制的。Kubernetes 提供了兩個參數 maxSurge maxUnavailable 來精細控制 Pod 的替換數量,我們將在后面結合 Health Check 特性一起討論。

?

更新回滾

?

kubectl apply 每次更新應用時 Kubernetes 都會記錄下當前的配置,保存為一個 revision(版次),這樣就可以回滾到某個特定 revision。

默認配置下,Kubernetes 只會保留最近的幾個 revision,可以在 Deployment 配置文件中通過 revisionHistoryLimit 屬性增加 revision 數量。

?

第一步:下面實踐回滾功能。

應用有如下三個配置文件 httpd.v1.yml,httpd.v2.yml 和 httpd.v3.yml,分別對應不同的 httpd 鏡像 2.4.16,2.4.17 和 2.4.18:

?

第二步:部署應用并更新

后面一個部署的應用,會覆蓋掉前面的(名稱相同)

[root@ken ~]# kubectl apply -f httpd_v1.yml --record deployment.apps/httpd created [root@ken ~]# kubectl get deployment httpd -o wide NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR httpd 3/3 3 3 18s httpd httpd:2.4.16 run=httpd[root@ken ~]# kubectl apply -f httpd_v2.yml --record deployment.apps/httpd configured [root@ken ~]# kubectl get deployment httpd -o wide NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR httpd 3/3 2 3 75s httpd httpd:2.4.17 run=httpd[root@ken ~]# kubectl apply -f httpd_v3.yml --record deployment.apps/httpd configured [root@ken ~]# kubectl get deployment httpd -o wide NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR httpd 3/3 1 3 94s httpd httpd:2.4.18 run=httpd

--record 的作用是將當前命令記錄到 revision 記錄中,這樣我們就可以知道每個 revison 對應的是哪個配置文件。

?

第三步:通過 kubectl rollout history deployment httpd 查看 revison 歷史記錄。

[root@ken ~]# kubectl rollout history deployment httpd deployment.extensions/httpd REVISION CHANGE-CAUSE 1 kubectl apply --filename=httpd_v1.yml --record=true 2 kubectl apply --filename=httpd_v2.yml --record=true 3 kubectl apply --filename=httpd_v3.yml --record=true

CHANGE-CAUSE 就是 --record 的結果。

?

第四步:如果要回滾到某個版本,比如 revision 1,可以執行命令 kubectl rollout undo deployment httpd --to-revision=1:

[root@ken ~]# kubectl rollout undo deployment httpd --to-revision=1 deployment.extensions/httpd rolled back [root@ken ~]# kubectl get deployment httpd -o wide NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR httpd 3/3 3 3 5m26s httpd httpd:2.4.16 run=httpd

?

第五步:此時,revison 歷史記錄也會發生相應變化。

[root@ken ~]# kubectl rollout history deployment httpd deployment.extensions/httpd REVISION CHANGE-CAUSE 2 kubectl apply --filename=httpd_v2.yml --record=true 3 kubectl apply --filename=httpd_v3.yml --record=true 4 kubectl apply --filename=httpd_v1.yml --record=true

revison 1 變成了 revison 4。不過我們可以通過 CHANGE-CAUSE 知道每個 revison 的具體含義。所以一定要在執行 kubectl apply 時加上 --record參數。

轉載于:https://www.cnblogs.com/kenken2018/p/10336267.html

總結

以上是生活随笔為你收集整理的k8s滚动更新(六)--技术流ken的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 空姐吹箫视频大全 | 处女朱莉| 去毛片| 国产精品福利视频 | 黑人玩弄人妻一区二区三区免费看 | 男人天堂v | 青青草视频污 | 麻豆网站视频 | 女人扒开腿免费视频app | 驯服少爷漫画免费观看下拉式漫画 | 日韩精品你懂的 | 女生被男生桶 | 日韩天堂在线视频 | 超碰偷拍 | 亚洲人在线视频 | 欧美最顶级a∨艳星 | 九草av | 91久久精品在线 | 免费在线黄色网 | 99草视频| 女人扒开腿让男人桶爽 | 欧美乱视频 | 污视频网站免费观看 | 天天超碰 | 亚洲成熟丰满熟妇高潮xxxxx | 欧美亚洲激情 | 日韩中文字幕2019 | 国产精品资源站 | 色播五月综合 | 深夜成人在线 | 亚洲国产精品视频一区二区 | 韩国三色电费2024免费吗怎么看 | 大奶子网站 | 亚洲一片| 亚洲福利视频一区二区三区 | 男人舔女人下部高潮全视频 | 欧美乱妇狂野欧美视频 | 男男全肉变态重口高h | 亚洲第一视频在线播放 | 日日摸夜夜添狠狠添久久精品成人 | 精品久久BBBBB精品人妻 | 日韩综合精品 | 色黄啪啪网 | 久热免费在线 | 激情五月五月婷婷 | av在线网站观看 | 国模婷婷 | 日本少妇bb | 好男人在线观看 | 亚洲自拍偷拍一区 | 久艹在线视频 | 国产精品毛片久久久久久久av | 国产三级久久 | 国产精品无码免费在线观看 | 911国产在线 | 毛片天天看 | 日日射日日操 | 漂亮人妻被中出中文字幕 | 欧美做爰爽爽爽爽爽爽 | 久久一久久 | 中文字幕观看av | 亚洲天堂黄 | 久久久免费精品视频 | 欧美在线播放一区二区 | 久久九九免费 | 久久精品国产一区 | 国产午夜小视频 | 国产亚洲精品久 | 99久久精品国产色欲 | 国产成人精品免费视频 | 黄色一级大片在线观看 | 亚洲五月激情 | 性xxxx视频 | 性xxx18| 国产一级片免费观看 | 亚洲天堂一区二区在线 | 人人爽人人做 | 免费观看a毛片 | 高清福利视频 | 中国毛片网| 成人免费版欧美州 | 免费在线看黄的网站 | 亚洲黄色免费视频 | 精品人妻伦一二三区久久 | 欧日韩在线观看 | 成人特级毛片 | 国产欧美高清 | 中国丰满老妇xxxxx交性 | 精品久久中文 | 久久精品中文闷骚内射 | 亚洲av综合av一区二区三区 | 丰满人妻老熟妇伦人精品 | 日韩欧美123 | 超碰人人网 | 在线免费观看av不卡 | 久章草在线观看 | 美女又爽又黄免费 | 我把护士日出水了视频90分钟 | 欧美一区二区三区久久成人精品 |