StatefulSet 是用来管理有状态应用的控制器
StatefulSet 用来管理某Pod集合的部署和扩缩, 并为这些 Pod 提供持久存储和持久标识符
StatefulSet | KubernetesStatefulSet 运行一组 Pod,并为每个 Pod 保留一个稳定的标识。 这可用于管理需要持久化存储或稳定、唯一网络标识的应用。https://kubernetes.io/zh/docs/concepts/workloads/controllers/statefulset/
yaml文件
Groovy
#statefulset部分
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: web # statefulset的名称
spec:
serviceName: "nginx"
replicas: 3 # 3个副本
updateStrategy: #更新策略
type: RollingUpdate #滚动更新
rollingUpdate: #滚动更新分区数
partition: 3
selector:
matchLabels: #匹配pod标签为app=nginx
app: nginx
template: #pod模板
metadata:
labels:
app: nginx #标签为app=nginx,statefulset和上面service标签选择器与之对应
spec:
containers:
- name: nginx
image: nginx:1.15-alpine
ports:
- containerPort: 80
name: web
volumeMounts: #存储卷定义
- name: www #存储卷名称
mountPath: /usr/share/nginx/html #位置
volumeClaimTemplates: #存储卷
- metadata:
name: www #上面valumemounts须相同
spec:
accessModes: [ "ReadWriteOnce" ] #读写权限
storageClassName: "nfs-client" # 与前面定义的storageclass名称对应
resources:
requests:
storage: 1Gi
查看
bash
kubectl get statefulset
或者简写 kubectl get sts
bash
[root@k8s-master ~]# kubectl get sts -n nacos
NAME READY AGE
nacos 1/1 20d
扩容缩容
bash
# 扩容缩容,指定副本数大则扩容,小则缩容
kubectl scale statefulset web --replicas=5
# 扩容缩容
kubectl patch statefulset web -p '{"spec":{"replicas":3}}'
当然,修改yaml文件中的replicas后再执行kubectl apply -f yaml-name也可以
删除
级联删除
bash
# 级联删除:删除 statefulset 时会同时删除 pods
kubectl delete statefulset web
非级联删除 --cascade=false
bash
# 非级联删除:删除 statefulset 时不会删除 pods,删除 sts 后,pods 就没人管了,此时再删除 pod 不会重建的
#1.删除statefulset
kubectl deelte sts web --cascade=false
#2.删除service
kubectl delete service nginx
#3.删除pod
kubectl delete pod nginx
删除pvc
bash
# StatefulSet删除后PVC还会保留着,数据不再使用的话也需要删除
$ kubectl delete pvc www-web-0 www-web-1
镜像更新
两个方式
-
RollingUpdate
滚动更新,同样是修改 pod template 属性后会触发更新,但是由于 pod 是有序的,在 StatefulSet 中更新时是基于 pod 的顺序倒序更新的
利用滚动更新中的 partition 属性,可以实现简易的灰度发布的效果
-
onDelete
当pod被删除后更新
更新镜像版本
bash
kubectl set image sts/web nginx=nginx:latest
灰度发布
例如我们有 5 个 pod,如果当前 partition 设置为 3,那么此时滚动更新时,只会更新那些 序号 >= 3 的 pod
利用该机制,我们可以通过控制 partition 的值,来决定只更新其中一部分 pod,确认没有问题后再主键增大更新的 pod 数量,最终实现全部 pod 更新