在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和擴充以及更新策略。
感謝大大教學。另外說一下,程式碼區塊下方來源部分,最後一個括號被當成網址的一部分了直接點會404,拿掉後就可以正常連到囉。