k8s-第五节-StatefulSet

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

相关推荐
幺零九零零37 分钟前
Docker底层-Namespaces
运维·docker·容器
Ancelin安心1 小时前
Windows搭建和使用vulhub的一些常用命令
linux·运维·服务器·网络安全·docker·容器·vulhub
仰望星空的打工人2 小时前
雨云云应用部署frp
服务器·docker·容器
汪碧康2 小时前
【k8s-1.34.2安装部署】九.k8s多集群管理平台xkube-v3.9安装部署
云原生·容器·kubernetes·kubelet·xkube·eeenet
java_logo3 小时前
LocalAI Docker 容器化部署指南
docker·容器·eureka·localai·docker部署localai·localai部署教程·localai部署文档
逆流°只是风景-bjhxcc3 小时前
【k8s】Kubernetes 探针(livenessProbe、readinessProbe、startupProbe)
云原生·容器·kubernetes
逆流°只是风景-bjhxcc3 小时前
【k8s】Kubernetes(K8s)YAML 配置文件
docker·容器·kubernetes
理智的煎蛋4 小时前
单节点 K8S IP 修改步骤
tcp/ip·云原生·容器·kubernetes
眠りたいです4 小时前
Docker:Docker Volume存储卷-宿主机与容器的数据双向交流通道
运维·docker·中间件·容器
幺零九零零5 小时前
Docker底层-Namespaces(网络隔离)
网络·docker·容器