k8s-----12、controller-StatefulSet

StatefulSet

1、有状态和无状态的区别

1.1 无状态

  • 认为pod都是一样的
  • 随意进行伸缩和扩展
  • 没有顺序要求
  • 不用考虑在哪一个node运行

1.2 有状态

  • 无状态的因素都需要考虑到
  • 让每个pod独立,保持Pod启动顺序和唯一性。如唯一的网络标识符或者持久存储。有序状态,如mysql主从。

2、部署有状态应用

2.1 部署要求

  • 首先需要创建一个无头service,即clusterIP: None
  • deployment和statefulSet的区别是:有身份的(唯一标识)
  • 每一个pod有唯一的主机名。
  • 每一个pod有唯一域名。域名规则:主机名称.service名称.名称空间.svc.cluster.local

2.2 实战部署

bash 复制代码
[root@master controlleryaml]# vim sts.yaml 

apiVersion: v1
kind: Service
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  ports:
  - port: 80
    name: web
  clusterIP: None      ##首先创建的无头service
  selector:
    app: nginx

---

apiVersion: apps/v1
kind: StatefulSet    ##创建带有statefulSet的有状态控制器
metadata:
  name: nginx-statefulset
  namespace: default
spec:
  serviceName: nginx
  replicas: 3    # 3个会顺序启动
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:latest
        ports:
        - containerPort: 80
[root@master controlleryaml]# kubectl apply -f sts.yaml
[root@master controlleryaml]# kubectl get pods   #查看pod 的唯一标识
NAME                  READY   STATUS    RESTARTS   AGE
nginx-statefulset-0   1/1     Running   0          70s
nginx-statefulset-1   1/1     Running   0          67s
nginx-statefulset-2   1/1     Running   0          51s

[root@master controlleryaml]# kubectl get  svc     # 查看service
NAME         TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   61d
nginx        ClusterIP   None         <none>        80/TCP    92s   # None的无头service
相关推荐
阿里云云原生4 小时前
告别冗长链路!Kafka × Table Bucket 实现开放表格式零 ETL 实时入湖
云原生·kafka
SelectDB21 小时前
秒级弹性、最高降本 70%:SelectDB Serverless 如何重塑云数仓资源效率
大数据·后端·云原生
武子康3 天前
调查研究-183 Apple container:Mac 上用轻量 VM 跑 Linux 容器,Swift 会改写本地容器体验吗?
docker·容器·apple
秋播3 天前
国内本地WSL2编译rancher源码
云原生
小猿姐5 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
阿里云云原生6 天前
深入内核:拆解 OpenTelemetry eBPF 探针如何优雅地“透视”多语言微服务?
云原生
2601_961875246 天前
决战申论100题2026|最新|范文
linux·容器·centos·debian·ssh·fabric·vagrant
java_cj6 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
程序员老赵6 天前
服务器没有桌面?Docker 跑个 Chrome,浏览器就能远程用
docker·容器·devops
正经教主6 天前
【docker基础】 第八周:容器监控与应用更新策略
运维·docker·容器