Kubernetes详解(四十七)——statefulset扩展
今天继续给大家介绍Linux运维相关知识,本文主要内容是statefulset扩展。
在上文Kubernetes详解(四十五)——statefulset控制器原理和Kubernetes详解(四十六)——statefulset控制器实战中,我们分别介绍了StatefulSet控制器的原理和创建实战。今天,我们来介绍一下StatefulSet控制器的滚动更新、域名解析、扩容缩容以及更新策略。
一、statefulset滚动更新
我们修改StatefulSet的资源清单,将StatefulSet控制器下Pod的image修改为v2v版本。之后,我们使用修改后的资源清单重新创建StatefulSet,同时,打开其他的终端,动态的观察StatetfulSet控制器的更新过程,结果如下所示:
从上图中可以看出,我们的StatefulSet控制器在更新时也是有顺序的,会严格按照序号从大到小的顺序进行更新。
二、statefulset解析
在StatefuSet控制器中,每个Pod都是可以解析的。
我们在运行StatefulSet控制器后,进入该控制器下的Pod,并执行命令:
nslookup statefulset-exp-0.headless-svc.default.svc.cluster.local
尝试解析该控制器,结果如下所示:
从上图中可以看出,我们在进行Pod后,对该StatefulSet控制器下的不同的Pod都是可以解析到该Pod的IP地址的。
三、statefulset扩容和缩容
StatefulSet控制器支持扩容和缩容。
在StatefulSet扩容时,会创建一个新的Pod,该Pod与之前的所有Pod都是有顺序的,并且新Pod的序号最大。在缩容时,StatefulSet控制器删除的也是序号最大的Pod。
执行命令:
kubectl scale sts statefulset-exp --replicas=4
即可指定该StatefulSet控制器下的容器副本数为4,该命令执行结果以及扩容后的状态如下所示:
如果我们在其他终端上动态观察扩容结果,则如下所示:
四、Statefulset更新策略
StatefulSet可以使用partition参数来实现金丝雀更新,partition参数可以控制StatefulSet控制器更新的Pod。下面,我们就进行StatefulSet控制器的金丝雀更新实战。
首先,执行命令:
kubectl patch sts statefulset-exp -p '{"spec":{"updateStrategy":{"rollingUpdate":{"partition":2}}}}'
该命令使用patch参数来指定了StatefulSet控制器的partition参数为2,表示当更新时,只有Pod的编号大于等于2的才更新。
之后,我们执行命令:
kubectl set image sts/statefulset-exp myapp=ikubernetes/myapp:v3
来控制StatefulSet下的Pod更新到v3版本的myapp镜像。
之后,我们执行命令:
kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image
来查看更新情况。
上述过程如下所示:
从上图中我们可以看出,在StatefulSet控制器更新后,我们的2和3的Pod变成了v3版本,而0和1的Pod仍旧是v2版本。
之后,如果我们想要设置StatefulSet下的控制器全部更新,我们需要首先将partition参数更改为0,执行命令:
kubectl patch sts statefulset-exp -p '{"spec":{"updateStrategy":{"rollingUpdate":{"partition":0}}}}'
之后,我们再执行命令:
kubectl set image sts/statefulset-exp myapp=ikubernetes/myapp:v3
来设置Pod的镜像版本。这样,就可以实现StatefulSet控制器的全部更新了,上述过程如下所示:
在此过程中,我们查看Pod更新的动态过程,结果如下:
从以上结果可以看出,我们的StatefulSet控制器金丝雀更新成功!
原创不易,转载请说明出处:https://blog.csdn.net/weixin_40228200
相关文章
- 实践:Kubernetes 集群中 DNS 故障的可观测性与根因诊断
- Kubernetes详解(十四)——Pod对象生命周期
- Kubernetes详解(五十六)——Dashboard安装与部署
- 【云原生 | Kubernetes 系列】Volume
- [K8s] Kubernetes 是什么 不是什么
- Kubernetes Helm入门指南
- 为什么Kubernetes要引入pod的概念,而不直接操作Docker容器
- k4.第二章 基于二进制包安装kubernetes v1.20 -- 集群部署(二)
- y51.第三章 Kubernetes从入门到精通 -- k8s实战案例(二四)
- 【云原生之kubernetes】kubernetes集群下Secret存储对象的管理
- SpringCloud微服务电商系统在Kubernetes集群中上线详细教程
- Kubernetes 存储架构体系
- 【云原生 | Kubernetes 系列】--Istio基础和部署
- a37.ansible 生产实战案例 -- 基于二进制包安装kubernetes v1.23 -- 集群部署(一)
- a27.ansible 生产实战案例 -- 基于二进制包安装kubernetes v1.21 -- 集群部署(一)
- kubernetes 迁移容灾备份(velero)