StatefulSet
StatefulSet
是用来管理有状态的应用,例如数据库。
前面我们部署的应用,都是不需要存储数据,不需要记住状态的,可以随意扩充副本,每个副本都是一样的,可替代的。
而像**数据库、Redis **这类有状态的,则不能随意扩充副本。
StatefulSet 会固定每个 Pod 的名字
yaml
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mongodb
spec:
serviceName: mongodb
replicas: 3
selector:
matchLabels:
app: mongodb
template:
metadata:
labels:
app: mongodb
spec:
containers:
- name: mongo
image: mongo:4.4
# IfNotPresent 仅本地没有镜像时才远程拉,Always 永远都是从远程拉,Never 永远只用本地镜像,本地没有则报错
imagePullPolicy: IfNotPresent
---
# 定义 HeadLess service
apiVersion: v1
kind: Service
metadata:
name: mongodb
spec:
selector:
app: mongodb
type: ClusterIP
# HeadLess 就不再给Service分配IP了,通过pod名字访问
clusterIP: None
ports:
- port: 27017
targetPort: 27017
StatefulSet 特性
- Service 的
CLUSTER-IP
是空的,Pod
名字也是固定的。 - Pod 创建和销毁是有序的,创建是顺序的,销毁是逆序的,可以从创建的序号看出来0,1,2,3...。
- Pod 重建不会改变名字,除了IP,所以不要用IP直连.
创建 statefulset 会在endpoints 多一个 hostname,用于service和pod之间做dns指向
- 访问时,如果直接使用
Service
名字连接,会随机转发请求连接指定Pod
,可以这样pod-name.service-name
测试连接
运行一个临时 Pod 连接数据测试下
kubectl run mongodb-client --rm --tty -i --restart='Never' --image docker.io/bitnami/mongodb:4.4.10-debian-10-r20 --command -- bash
进去bash 后 使用
mongo --host mongodb
为随机转发连接mongodb service下的pod
mongo --host mongodb-0.mongodb
为直接连接mongodb-0 pod