k8s学习--资源控制器StatefulSet详细解释与应用

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: StatefulSet 是 Kubernetes 中用于管理有状态应用的控制器,提供稳定的网络标识符和持久化存储能力。相较于 Deployment、DaemonSet 等无状态服务控制器,StatefulSet 支持有状态服务如 MySQL、Redis 等集群的部署和管理。本文详细介绍 StatefulSet 的概念、特点及部署方法,并通过具体示例展示了如何配置 NFS 存储及 StatefulSet 应用,确保每个 Pod 拥有独立且持久的数据存储空间。

一 StatefulSet是什么?

statefulset是什么

是k8s中常见的pod控制器类型之一

k8s中常见的pod控制器类型有哪些

ReplicaSet:即RS
Deployment
DaemonSet:即DS
StatefulSet
Job
Cronjob

statefulset与其他pod控制器的区别是什么

我们在生产中常用的副本(pod)控制器如Deployment,DaemonSet,RS都是使用于无状态服务,其所管理的Pod的启停顺序,IP,Pod名称都是随机的,被管理的Pod更新时,这些都会发生变化,而我们在管理如mysql,redis,kafka,consul这些集群是为了管理方便,就可以使用
有状态服务statefulSet
Kubernetes中StatefulSet是专为有状态服务如mysql、redis、kafka、consul等集群准备的集合,管理所有有状态服务。
:无状态服务同样可以使用statefulset控制器

有状态服务和无状态服务区别是什么

简单理解(个人理解)
无状态服务里随机的参数(Pod的启停顺序、IP、Pod名称)在有状态服务里都不是随机的,有顺序的

详细解释
无状态服务(Stateless Services):

1.在 Kubernetes 中,无状态服务通常以 Deployment 或者 ReplicaSet 的方式进行部署和管理。

2.无状态服务的实例可以随意扩展和收缩,因为它们之间是相互替换的,而且不需要关注特定实例的状态。

3.无状态服务可以使用水平扩展来应对高负载,Kubernetes 可以根据实际负载自动添加或移除实例。

有状态服务(Stateful Services):

1.在 Kubernetes 中,有状态服务通常以 StatefulSet 的方式进行部署和管理。

2.StatefulSet 提供了稳定的网络标识和持久化存储的能力,确保每个实例都有唯一的标识并且可以使用持久化卷来保存状态数据。

3.有状态服务的实例通常需要按照确定的顺序部署和扩展,因为它们的状态数据可能会影响到服务的行为。

StatefulSet作用

主要用来管理有状态应用的控制器。
用来管理某Pod集合的部署和扩缩,并为这些 Pod 提供持久存储和持久标识符。

statefulSet的特点

1.稳定的网络标识:StatefulSet 中的每个 Pod 都有一个稳定的网络标识符(例如 hostname),这使得这些 Pod 可以有确定的网络身份,并且可以被其他应用程序依赖和访问。

2.有序部署和扩展:StatefulSet 保证 Pod 的部署和扩展是按照确定的顺序进行的,每个 Pod 都有一个唯一的标识符,这对于需要有序启动和停止的应用程序非常重要。

3.持久化存储:StatefulSet 支持使用持久卷(PersistentVolume)来存储 Pod 的状态数据,确保即使 Pod 被重新调度到其他节点,其状态数据也不会丢失。

4.自主管理的标识符:StatefulSet 可以为每个 Pod 分配一个自主管理的标识符,例如在有状态服务中使用的索引或者名称。这些标识符可以在 Pod 重新启动或者重新调度后保持不变。

5.有状态服务的更新:StatefulSet 支持有状态服务的滚动更新,确保在更新过程中不会破坏服务的可用性,并且可以保持有状态服务的稳定性。

statefulSet组成

一个完整的StatefulSet应用由三个部分组成:

headless service、
StatefulSet controller、
volumeClaimTemplate。

headless service(无头服务)
简单来说就是没有群集ip

部署statefulset应用

Ip 主机名 cpu 内存 硬盘
192.168.10.11 master 1cpu双核 2G 40G
192.168.10.12 node01 1cpu双核 2G 40G
192.168.10.13 node02 1cpu双核 2G 40G
192.168.10.17 nfs 1cpu1核 1G 40G

虚拟机 centos7.9

master node01 node02 已部署k8s集群
版本 1.18.0

nfs服务器部署nfs

部署storageclass

(1)主机基础配置

由于nfs是新创建的虚拟机需要关闭防火墙,关闭沙盒

systemctl stop firewalld
systemctl disable firewalld
setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/sysconfig/selinux

(2)配置 NFS:

所有主机都需要安装nfs

yum -y install nfs-utils rpcbind

其次在nfs主机上

mkdir /nfsdata
vim /etc/exports
输入
/nfsdata *(rw,sync,no_root_squash)
systemctl start rpcbind
systemctl start nfs-server
systemctl enable rpcbind
systemctl enable nfs-server
showmount -e

看到这个nfs就部署成功了
image.png

(3)创建配置storageclass

yaml文件内容详见,这里不再过多记述
链接: storageclass详细解释与应用

创建账号、创建权限、给账号关联权限
[root@master ~]# kubectl apply -f account.yaml
通过中间件将访问账号与共享存储关联
[root@master ~]# kubectl apply -f nfs-deployment.yaml
配置storageclass与中间件关联
[root@master ~]# kubectl apply -f storageclass.yaml

2.部署headless service

为什么用headless service无头服务?
在用Deployment时,每一个Pod名称是没有顺序的,是随机字符串,因此是Pod名称是无序的,但是在statefulset中要求必须是有序,每一个pod不能被随意取代,pod重建后pod名称还是一样的。

在有状态服务中,pod名称是pod唯一性的标识符,必须持久稳定有效。这时候要用到无头服务,它可以给每个Pod一个唯一的名称。

**为什么用volumeClaim Template?
对于有状态的副本集都会用到持久存储,特别是对于分布式系统来讲,它的最大特点是数据是不一样的,所以各个节点不能使用同一存储卷,每个节点有自已的专用存储,

但是如果在Deployment中的Pod template里定义的存储卷,是所有副本集共用一个存储卷,数据是相同的,因为是基于模板来的,

而statefulset中每个Pod都要自已的专有存储卷,所以statefulset的存储卷就不能再用Pod模板来创建了,于是statefulSet使用volumeClaimTemplate,称为卷申请模板,它会为每个Pod生成不同的pvc,并绑定pv,从而实现各pod有专用存储。

3.Statefulset应用示例

[root@master yaml]# vim nfs-deployment.yaml

apiVersion: v1
kind: Service
metadata:
  name: headless-svc
  labels:
    app: headless-svc
spec:
  ports:
  - name: myweb
    port: 80
  selector:
    app: headless-pod
  clusterIP: None

---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: statefulset
spec:
  serviceName: headless-svc
  replicas: 3
  selector:
    matchLabels:
      app: headless-pod
  template:
    metadata:
      labels:
        app: headless-pod
    spec:
      containers:
      - name: myweb
        image: nginx:1.20
        imagePullPolicy: IfNotPresent
        volumeMounts:
        - name: test-storage
          mountPath: /usr/share/nginx/html
  volumeClaimTemplates:
  - metadata:
      name: test-storage
      annotations:
        volume.beta.kubernetes.io/storage-class: storageclass
    spec:
      accessModes:
        - ReadWriteOnce
      resources:
        requests:
          storage: 100Mi
[root@master yaml]# kubectl apply -f statefulset.yaml 
[root@master yaml]# kubectl get pv,pvc

image.png

从上面可以看到
storageclass自动创建了PV
volumeClaimTemplate自动创建了PVC
现在测试每一个Pod是否有自己独特的数据持久化目录,也就是说,每一个Pod内的数据是不是都是不一样的

分别在对应的PV下,模拟创建不同的数据。

[root@nfs ~]# echo 000 > /nfsdata/default-test-storage-statefulset-0-pvc-6ff2b4bf-789a-4fd3-987e-72db4fb2fa09/testfile
[root@nfs ~]# echo 111 > /nfsdata/default-test-storage-statefulset-1-pvc-7076ef24-3ea7-419a-abed-4dc27886681a/testfile
[root@nfs ~]# echo 222 > /nfsdata/default-test-storage-statefulset-2-pvc-bc5df9e7-183e-4c70-9574-e8cb48823bae/testfile

查看对应Pod的数据持久化目录,可以看出,每个Pod的内容都不一样

[root@master yaml]# kubectl exec -it statefulset-0 -- cat /usr/share/nginx/html/testfile
000
[root@master yaml]# kubectl exec -it statefulset-1 -- cat /usr/share/nginx/html/testfile
111
[root@master yaml]# kubectl exec -it statefulset-2 -- cat /usr/share/nginx/html/testfile
222

image.png

可以看到是不一样的

实验完成

如果对您有帮助就点个赞吧

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
1月前
|
存储 Kubernetes 持续交付
介绍一下Kubernetes的应用场景
【10月更文挑战第18天】介绍一下Kubernetes的应用场景。
135 3
|
1月前
|
存储 Kubernetes 持续交付
k8s学习
【10月更文挑战第1天】
85 4
|
12天前
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?
|
12天前
|
监控 持续交付 Docker
Docker容器化部署在微服务架构中的应用
Docker容器化部署在微服务架构中的应用
|
20天前
|
JavaScript 持续交付 Docker
解锁新技能:Docker容器化部署在微服务架构中的应用
【10月更文挑战第29天】在数字化转型中,微服务架构因灵活性和可扩展性成为企业首选。Docker容器化技术为微服务的部署和管理带来革命性变化。本文探讨Docker在微服务架构中的应用,包括隔离性、可移植性、扩展性、版本控制等方面,并提供代码示例。
55 1
|
29天前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景
|
14天前
|
存储 Kubernetes 调度
【赵渝强老师】K8s中Deployment控制器与StatefulSet控制器的区别
K8s中的Deployment控制器用于管理无状态应用程序,关注Pod数量、更新方式等;而StatefulSets控制器则管理有状态应用程序,提供持久存储和唯一标识符,适用于需要稳定网络标识符和持久化存储的场景。两者的主要区别在于是否维护状态和顺序。
|
14天前
|
存储 Kubernetes 调度
【赵渝强老师】K8s的有状态控制器StatefulSet
在Kubernetes中,StatefulSets用于部署有状态应用程序,提供持久存储和唯一标识符。与Deployment不同,StatefulSets确保Pod的标识符在重新调度后保持不变,适用于需要稳定网络标识符和持久存储的场景。本文介绍了StatefulSets的创建、扩容与缩容、更新与回滚等操作,并提供了具体示例和视频讲解。
|
1月前
|
存储 Kubernetes 调度
|
1月前
|
存储 Kubernetes 监控
深度解析Kubernetes在微服务架构中的应用与优化
【10月更文挑战第18天】深度解析Kubernetes在微服务架构中的应用与优化
109 0
下一篇
无影云桌面