我們緊接上一節(jié)的環(huán)境,進行下面的操作,如果不清楚的,可以先查看上一篇博文。
做網(wǎng)站、網(wǎng)站建設(shè),成都做網(wǎng)站公司-創(chuàng)新互聯(lián)公司已向成百上千企業(yè)提供了,網(wǎng)站設(shè)計,網(wǎng)站制作,網(wǎng)絡(luò)營銷等服務(wù)!設(shè)計與技術(shù)結(jié)合,多年網(wǎng)站推廣經(jīng)驗,合理的價格為您打造企業(yè)品質(zhì)網(wǎng)站。滾動更新是一次只更新一小部分副本,成功后,再更新更多的副本,最終完成所有副本的更新。滾動更新的大的好處是零停機,整個更新過程始終有副本在運行,從而保證了業(yè)務(wù)的連續(xù)性。
我們查看一下上一節(jié)的配置文件mytest-deploy.yaml
。
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: mytest
spec:
replicas: 3
template:
metadata:
labels:
run: mytest
spec:
containers:
- name: mytest
image: wangzan18/mytest:v1
ports:
- containerPort: 80
我們看到設(shè)定的鏡像版本為v1,我們查看一下創(chuàng)建的ReplicaSet
。
[root@master ~]# kubectl get rs -o wide
NAME DESIRED CURRENT READY AGE CONTAINERS IMAGES SELECTOR
mytest-88d46bf99 3 3 3 68m mytest wangzan18/mytest:v1 pod-template-hash=88d46bf99,run=mytest
目前運行的 Pod 由 ReplicaSet mytest-88d46bf99
進行控制,我們將配置文件中的 v1 替換為 v2,再次應(yīng)用。
[root@master ~]# kubectl apply -f mytest-deploy.yaml
deployment.extensions/mytest configured
[root@master ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
mytest-56c55b4c6-6gjxc 1/1 Running 0 24s
mytest-56c55b4c6-f5trx 1/1 Running 0 18s
mytest-56c55b4c6-sh6wd 1/1 Running 0 24s
mytest-88d46bf99-48f6n 1/1 Terminating 0 70m
mytest-88d46bf99-mv6cf 1/1 Terminating 0 70m
mytest-88d46bf99-p9w79 1/1 Terminating 0 70m
[root@master ~]# kubectl get deploy -o wide
NAME READY UP-TO-DATE AVAILABLE AGE CONTAINERS IMAGES SELECTOR
mytest 3/3 3 3 72m mytest wangzan18/mytest:v2 run=mytest
[root@master ~]# kubectl get rs -o wide
NAME DESIRED CURRENT READY AGE CONTAINERS IMAGES SELECTOR
mytest-56c55b4c6 3 3 3 59s mytest wangzan18/mytest:v2 pod-template-hash=56c55b4c6,run=mytest
mytest-88d46bf99 0 0 0 71m mytest wangzan18/mytest:v1 pod-template-hash=88d46bf99,run=mytest
我們可以看到 Deployment 的鏡像更新為wangzan18/mytest:v2
,創(chuàng)建了新的 ReplicaSet mytest-56c55b4c6
,并管理了三個新的 Pod。
[root@master ~]# kubectl describe deployment mytest
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal ScalingReplicaSet 4m9s deployment-controller Scaled up replica set mytest-56c55b4c6 to 1
Normal ScalingReplicaSet 4m9s deployment-controller Scaled down replica set mytest-88d46bf99 to 2
Normal ScalingReplicaSet 4m9s deployment-controller Scaled up replica set mytest-56c55b4c6 to 2
Normal ScalingReplicaSet 4m3s deployment-controller Scaled down replica set mytest-88d46bf99 to 1
Normal ScalingReplicaSet 4m3s deployment-controller Scaled up replica set mytest-56c55b4c6 to 3
Normal ScalingReplicaSet 4m3s deployment-controller Scaled down replica set mytest-88d46bf99 to 0
每次只更新替換一個 Pod。
kubectl apply
每次更新應(yīng)用時 Kubernetes 都會記錄下當前的配置,保存為一個 revision(版次),這樣就可以回滾到某個特定 revision。
默認配置下,Kubernetes 只會保留最近的幾個 revision,可以在 Deployment 配置文件中通過 revisionHistoryLimit
屬性增加 revision 數(shù)量。
通過命令kubectl rollout undo
我們可以回滾到上一個版本。
[root@master ~]# kubectl rollout undo deploy mytest
deployment.extensions/mytest rolled back
[root@master ~]# kubectl get rs -o wide
NAME DESIRED CURRENT READY AGE CONTAINERS IMAGES SELECTOR
mytest-56c55b4c6 0 0 0 12m mytest wangzan18/mytest:v2 pod-template-hash=56c55b4c6,run=mytest
mytest-88d46bf99 3 3 3 82m mytest wangzan18/mytest:v1 pod-template-hash=88d46bf99,run=mytest
可以看到三個 Pod 重新由鏡像為wangzan18/mytest:v1
的ReplicaSet進行接管。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。