Principles
- ensure the reproducibility:
- for kubernetes pods of the same application to communicate with each other
- find their storage
- use case
- Consul
- Elasticsearch
- Cassandra
StatefulSet
keep a sticky identify
for their kubernetes pods
Identity stickiness
data:image/s3,"s3://crabby-images/9b402/9b402caf9b6e6c9787f37202f9ebe7f5b36d0bf9" alt=""
Error management
data:image/s3,"s3://crabby-images/ba1b0/ba1b0796124cac01a366cdeb8ef8202cf9a26e2e" alt=""
Storage
data:image/s3,"s3://crabby-images/8d000/8d00060e319a627dc3c8828f5cf70b2d05ac0fd1" alt=""
data:image/s3,"s3://crabby-images/f1456/f14562c6f83121278de6184b4e4cf09598f5cae4" alt=""
Declaration
---
apiVersion: v1
kind: Service
metadata:
name: db-cluster-headless-svc
labels:
app: db-cluster
spec:
selector:
app: db-cluster
clusterIP: None
ports:
- port: 8080
name: db
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: db-cluster
labels:
app: db-cluster
spec:
replicas: 2
serviceName: db-cluster-headless-svc
selector:
matchLabels:
app: db-cluster
template:
metadata:
labels:
app: db-cluster
spec:
containers:
- name: db
image: foobar/k8s-training-statefulset:v1
ports:
- name: db
containerPort: 8080
volumeMounts:
- name: data
mountPath: /data
volumeClaimTemplates:
- metadata:
name: data
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 50Mi