在pod的生态中,本身就是一个小小世界,新旧pod之间通常不影响,当建立新的pod时,基本上不会跟被删除的pod有所关联。
因此当想要储存状态时就会很麻烦,只要pod重启,里面的内容就会消失,那麽这时该怎麽处理呢?
就是statefulset上场的时候了。
需要用到StatefulSets的情况没那麽常见,但是当你服务拥有以下要求,就会需要StatefulSets了:
上面这些情境都适合StatefulSets。
使用StatefulSets会有以下限制
apiVersion: v1
kind: Service
metadata:
name: nginx
labels:
app: nginx
spec:
ports:
- port: 80
name: web
clusterIP: None
selector:
app: nginx
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: web
spec:
selector:
matchLabels:
app: nginx # has to match .spec.template.metadata.labels
serviceName: "nginx"
replicas: 3 # by default is 1
template:
metadata:
labels:
app: nginx # has to match .spec.selector.matchLabels
spec:
terminationGracePeriodSeconds: 10
containers:
- name: nginx
image: k8s.gcr.io/nginx-slim:0.8
ports:
- containerPort: 80
name: web
volumeMounts:
- name: www
mountPath: /usr/share/nginx/html
volumeClaimTemplates:
- metadata:
name: www
spec:
accessModes: [ "ReadWriteOnce" ]
storageClassName: "my-storage-class"
resources:
requests:
storage: 1Gi
(来源:https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/)
上面的范例有几个重点:
上面这种yaml档就可以建立出StatefulSet了,在这章简单带过StatefulSet的使用情境以及yaml,下一章则会介绍StatefulSet内pod的Identity和扩充以及更新策略。
<<: 【Day14】[资料结构]-二元树走访Binary Tree Traversal
D29. C++字串 C++ string的特别用法 str.size():字串长度。 str.em...
我相信如果是使用微软产品的公司,大多数也都有使用Microsoft Teams作为公司内部的IM讯息...
如何验证正确率, 或如何辨别机器学习模型的好坏? 我们常使用Confusion Matrix[混淆矩...
续上一篇,今天要来讲的是一对多 还记得吗?我们昨天说的 我们希望每一间商店可以贩售许多种商品,这就是...
前言 今天我们要开始使用 Flask-WTF 来做表单,我们要做的表单还不少,但我们每个都会实作。他...