当前位置: 首页 > article >正文

【一起来学kubernetes】14、StatefulSet使用详解

      • 一、核心特性
      • 二、架构与组件
      • 三、生命周期管理
      • 四、典型应用场景**
      • 五、注意事项与最佳实践
      • 六、对比Deployment
        • 一、应用场景
        • 二、Pod管理
        • 三、部署与更新策略
        • 四、其他特性
      • 七、常见问题
      • 八、拓展

前文中我们介绍了k8s中常用的一种控制器 Deployment,与之向对应的,还有另外一种我们不太常用的控制器也是k8s的重要组成部分:StatefulSet,StatefulSet(有状态集,缩写为sts)是Kubernetes中用于部署和管理有状态应用程序的一种工作负载API对象。


一、核心特性

  1. 唯一标识与稳定性
    • 每个Pod分配唯一索引标识(如pod-0, pod-1),即使重启或迁移,标识不变。
    • 依赖Headless Service提供稳定DNS记录(如pod-0.example.com),确保客户端始终连接到同一实例。

StatefulSet是用来管理有状态应用的服务。和无状态的Deployment不同,StatefulSet需要保持每个Pod的唯一性和持久性。比如数据库、消息队列这样的应用,每个实例的数据都是独立的,不能随意替换或删除,这时候就需要StatefulSet来管理。

  1. 持久化存储
    • 通过volumeClaimTemplates自动生成独立的PersistentVolumeClaim(PVC),每个Pod拥有专属存储卷,数据持久化。

关于存储,每个Pod的volumeClaimTemplate会创建一个独立的PersistentVolumeClaim,确保数据隔离。如果使用本地存储的话,可能需要特别注意节点的可用性,否则数据可能会丢失。所以通常推荐使用云提供商的持久磁盘或者其他可靠的存储方案。

  1. 有序扩缩容
    • 扩容时按索引顺序创建新Pod(如从pod-2pod-N),缩容时逆序删除旧Pod(如先删pod-0),保障服务连续性。

  2. 滚动更新策略
    • 支持配置maxSurge(最大并发更新数)和maxUnavailable(最大不可用数),默认策略为逐个更新,减少对集群的影响。


二、架构与组件

StatefulSet Spec
定义Pod模板、副本数、服务名、标签选择器等关键参数:

apiVersion: apps/v1
kind: StatefulSet
metadata:name: my-database
spec:serviceName: "mysql-cluster" # 对应的Headless Service名称replicas: 3selector:matchLabels:app: mysqltemplate:metadata:labels:app: mysqlspec:containers:- name: mysqlimage: mysql:5.7volumeMounts:- name: db-datamountPath: /var/lib/mysqlvolumeClaimTemplates:- metadata:name: db-dataspec:accessModes:- ReadWriteOnceresources:requests:storage: 100Gi

Headless Service
自动创建无集群IP的Service,暴露所有Pod的DNS记录:

apiVersion: v1
kind: Service
metadata:name: mysql-cluster
spec:clusterIP: Noneselector:app: mysql
  • PersistentVolume Provisioner
    Pod所用的存储必须由PersistentVolume Provisioner(持久化卷配置器)根据请求配置StorageClass,或者由管理员预先配置。这是为了确保Pod在重新调度时能够访问到相同的持久化数据。

PersistentVolume Provisioner的配置通常涉及创建StorageClass对象,该对象定义了动态卷供应的参数和配置。以下是一个基于YAML的配置示例,展示了如何配置一个使用AWS EBS作为后端存储的PersistentVolume Provisioner。

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:name: standard
provisioner: kubernetes.io/aws-ebs
parameters:type: gp2reclaimPolicy: Delete
volumeBindingMode: Immediate

在这个例子中:

  • apiVersion 指定了Kubernetes API的版本,这里是storage.k8s.io/v1
  • kind 指定了这是一个StorageClass对象。
  • metadata.name 是这个StorageClass的名称,这里是standard
  • provisioner 指定了动态供应器的名称,这里是kubernetes.io/aws-ebs,表示使用AWS EBS作为后端存储。
  • parameters 部分包含了供应器特定的参数:
    • type 指定了EBS卷的类型,这里是gp2(通用型SSD)。
    • reclaimPolicy 指定了当PersistentVolume被删除时,后端存储的回收策略。这里是Delete,表示删除PV时也会删除对应的EBS卷。
    • volumeBindingMode 设置了卷绑定模式,这里是Immediate,表示在PVC创建时立即绑定PV。

请注意,这个配置示例是针对AWS EBS的。如果你使用其他类型的存储,比如NFS、Ceph等,你需要相应地更改provisionerparameters部分。

例如,如果你使用NFS作为后端存储,你的StorageClass配置可能看起来像这样:

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:name: nfs-storage
provisioner: example.com/nfs
parameters:path: /exports/dataserver: nfs-server.example.com

在这个NFS示例中:

  • provisioner 被设置为一个假想的NFS供应器名称example.com/nfs(在实际使用中,你需要替换为实际的NFS供应器名称)。
  • parameters 部分包含了NFS服务器的地址和共享路径。

要应用这个YAML配置,你可以使用kubectl create -f <filename>.yaml命令,其中<filename>.yaml是你的YAML文件的名称。例如:

kubectl create -f storageclass-nfs.yaml

这将创建一个名为nfs-storage的StorageClass对象,用于动态供应NFS类型的PersistentVolumes。请确保你的Kubernetes集群已经配置了相应的动态供应器,并且该供应器能够访问你指定的后端存储。


三、生命周期管理

StatefulSet的生命周期管理。当增加或减少副本时,它会按顺序创建或删除Pod,确保旧的Pod先下线,新的Pod再上线,这样可以避免服务中断。而Deployment则是并行更新的,可能导致短暂的服务不可用。不过,这也要看具体的更新策略设置是否正确。主要的步骤有如下的几步:

  1. 创建与扩展
    • 执行kubectl apply -f statefulset.yaml创建资源。
    • 扩容:kubectl scale statefulset my-database --replicas=5,按索引顺序新增Pod。

  2. 更新与滚动机制
    • 修改Pod镜像触发更新,新Pod按索引顺序启动,旧Pod逐步终止。
    • 可观察kubectl describe statefulset中的UpdateStrategyProgress

  3. 删除与清理
    • 缩容至0后删除StatefulSet,自动清理关联的PVC(需设置storageClassName并配置回收策略)。


四、典型应用场景**

  1. 数据库集群(MySQL、MongoDB、 ClickHouse)
    每个Pod作为独立数据库实例,数据持久化且可通过稳定域名连接。

  2. 消息队列(Kafka、RabbitMQ, RocketMq)
    Broker节点需要唯一标识和持久存储,确保分区和数据的分布一致性。

  3. 缓存系统(Redis Cluster)
    实例间需协同工作,StatefulSet帮助管理节点位置和故障转移。

StatefulSet的应用场景,除了数据库,像Redis集群、Kafka这样的分布式系统也可能用到。例如,Kafka的Broker需要每个实例对应不同的分区,这时候StatefulSet可以方便地管理和扩展。


五、注意事项与最佳实践

  1. 存储配置
    • 使用StorageClass动态供应PVC,避免手动创建。
    • 根据业务需求设置accessModes(如ReadWriteOnceReadWriteMany)。

  2. 更新策略
    • 生产环境建议设置maxUnavailable: 1,防止大规模宕机:

    updateStrategy:type: RollingUpdaterollingUpdate:maxSurge: 1maxUnavailable: 1
    
  3. 监控与调试
    • 使用kubectl get pods -w观察Pod状态变化。
    • 结合Prometheus监控存储使用率和Pod健康状态。

监控和维护方面,可能需要关注StatefulSet的状态,比如当前有多少个Pod处于就绪状态,是否有重建或升级正在进行。同时,需要定期检查每个Pod的日志和健康状况,确保数据的一致性和服务的稳定性。

  1. 高可用性
    • 配合Deployment部署StatefulSet控制器,实现自我修复。
    • 在多可用区部署时,结合云厂商的托管数据库服务(如AWS RDS)。

六、对比Deployment

特性StatefulSetDeployment
网络标识稳定DNS(pod-0.example.com)随机IP(pod-a.example.com)
存储每个Pod独立PVC共享Volume或无存储
扩缩容顺序有序(索引递增/递减)无序
适用场景数据库、消息队列等有状态应用无状态微服务、批处理任务

StatefulSet与Deployment都是Kubernetes中用于管理Pod的资源对象,但它们的设计目的和服务场景有所不同。以下是StatefulSet与Deployment的主要区别:

一、应用场景
  1. Deployment

    • 主要用于管理无状态应用。
    • 无状态应用通常不需要持久化数据或唯一网络标识符。
    • Deployment提供了一种简单的方式来部署和更新应用,支持滚动更新和回滚。
  2. StatefulSet

    • 主要用于管理有状态应用。
    • 有状态应用需要持久化数据或具有唯一网络标识符。
    • StatefulSet提供了持久化存储和稳定的网络标识符,适用于需要保持数据完整性和服务身份的应用。
二、Pod管理
  1. Pod命名与标识

    • Deployment:Pod名称是随机生成的,没有固定的顺序或标识。每个Pod都是可替换的,具有相同的配置和环境。
    • StatefulSet:Pod名称是基于索引的,具有固定的顺序和标识。每个Pod都有一个唯一的、持久的身份标识。
  2. 存储

    • Deployment:Pod通常共享存储卷,但这不适用于有状态应用,因为数据可能会相互干扰。
    • StatefulSet:每个Pod可以有独自的存储卷,通常与PersistentVolumeClaim(PVC)结合使用,以确保数据的持久化和隔离。
  3. 网络标识符

    • Deployment:Pod没有稳定的网络标识,通常通过Service进行通信。
    • StatefulSet:Pod具有稳定的网络标识,如DNS名称,可以通过Headless Service精确访问到每一个Pod。
三、部署与更新策略
  1. 部署

    • Deployment:通过ReplicaSet管理Pod的副本数,支持滚动更新策略,允许逐个替换Pod以保持服务的可用性。
    • StatefulSet:支持有序的创建和删除Pod,这在需要特定顺序执行初始化脚本或清理操作的情况下非常有用。StatefulSet不直接支持滚动更新,因为需要考虑数据的一致性和服务的连续性,更新过程通常需要更谨慎的操作,可能需要手动干预。
  2. 回滚

    • Deployment:支持自动回滚和暂停/恢复更新。
    • StatefulSet:更新过程需要更谨慎的操作,回滚也可能需要手动管理。
四、其他特性
  • Deployment:适用于Web应用服务器、微服务以及任何不需要持久化数据或特定网络标识的应用。
  • StatefulSet:适用于数据库集群(如MySQL、Cassandra)、分布式缓存系统(如Redis集群)以及任何需要持久化数据或特定网络标识的应用。

Deployment和StatefulSet各有其适用场景和特性。在选择使用哪个资源对象时,应根据应用的具体需求进行考虑。对于无状态应用,使用Deployment可以提供简便的部署和更新流程;而对于有状态应用,使用StatefulSet可以确保数据的安全性和服务的连续性。


七、常见问题

Q: Pod无法获取唯一标识?
A: 确保serviceName正确,并检查Headless Service的DNS解析是否正常。

Q: 数据丢失怎么办?
A: 验证PVC的reclaimPolicy(如DeleteRetain),并检查备份策略。

Q: 更新过程中服务中断?
A: 调整maxUnavailablemaxSurge,或采用蓝绿部署替代滚动更新。


通过合理利用StatefulSet,开发者可以高效管理复杂的有状态应用,确保数据的可靠性和服务的稳定性。理解其底层机制和最佳实践,是构建健壮Kubernetes集群的关键一步。

八、拓展

【一起来学kubernetes】11、Deployment使用详解

【一起来学kubernetes】13、k8s中的controller的前世今生

【一起来学kubernetes】0、通过yum安装k8s过程中常见异常处理

相关文章:

【一起来学kubernetes】14、StatefulSet使用详解

一、核心特性二、架构与组件三、生命周期管理四、典型应用场景**五、注意事项与最佳实践六、对比Deployment一、应用场景二、Pod管理三、部署与更新策略四、其他特性 七、常见问题八、拓展 前文中我们介绍了k8s中常用的一种控制器 Deployment&#xff0c;与之向对应的&#xff…...

Day5 结构体、文字显示与GDT/IDT初始化

文章目录 1. harib02b用例&#xff08;使用结构体&#xff09;2. harib02c用例3. harib02d用例&#xff08;显示字符图案&#xff09;3. harib02e用例&#xff08;增加字符图案&#xff09;4. harib02g用例4.1 显示字符串4.2 显示变量值 5. harib02h用例&#xff08;显示鼠标&a…...

AI第一天 自我理解笔记--微调大模型

目录 1. 确定目标&#xff1a;明确任务和数据 2. 选择预训练模型 3. 数据预处理 (1) 数据清洗与格式化 (2) 划分数据集 (3) 数据加载与批处理 4. 构建微调模型架构 (1) 加载预训练模型 (2) 修改模型尾部&#xff08;适配任务&#xff09; (3) 冻结部分层&#xff08;可…...

ClientAbortException问题分析

最近遇到一个问题&#xff0c;在设备采数据数据上报后频繁发生ClientAbortException异常&#xff0c;一种处理方案是ClientAbortException 问题分析-CSDN博客 一、ClientAbortException 的触发与影响 1. 定义与场景 ClientAbortException 是后端服务器&#xff08;如 Tomc…...

系统思考全球化落地

感谢加密货币公司Bybit的再次邀请&#xff0c;为全球团队分享系统思考课程&#xff01;虽然大家来自不同国家&#xff0c;线上学习的形式依然让大家充满热情与互动&#xff0c;思维的碰撞不断激发新的灵感。 尽管时间存在挑战&#xff0c;但我看到大家的讨论异常积极&#xff…...

【开原宝藏】30天学会CSS - DAY1 第一课

下面提供一个由浅入深、按步骤拆解的示例教程&#xff0c;让你能从零开始&#xff0c;逐步理解并实现带有旋转及悬停动画的社交图标效果。为了更简单明了&#xff0c;以下示例仅创建四个图标&#xff08;Facebook、Twitter、Google、LinkedIn&#xff09;&#xff0c;并在每一步…...

钉钉项目报销与金蝶系统高效集成技术解析

钉钉报销【项目报销类】集成到金蝶付款单【画纤骨】的技术实现 在企业日常运营中&#xff0c;数据的高效流转和准确对接是提升业务效率的关键。本文将分享一个具体的系统对接集成案例&#xff1a;如何将钉钉平台上的项目报销数据无缝集成到金蝶云星空的付款单系统中。本次方案…...

Python——代码格式

代码格式 良好的代码格式可以提升代码的可读性。和其他语言不同&#xff0c;Python 代码的格式是 Python 语法的组成之一&#xff0c;不符合 Python 代码无法正常运行。 注释 注释是代码中穿插的辅佐性质的文字&#xff0c;用于标识代码的含义和功能&#xff0c;可以提高程序…...

Datawhale coze-ai-assistant:Task 1 了解 AI 工作流 + Coze的介绍

学习网址&#xff1a;Datawhale-学用 AI,从此开始 工作流&#xff08;Workflow&#xff09;是指完成一项任务或目标时&#xff0c;按照特定顺序进行的一系列活动或步骤。它强调在计算机应用环境下的自动化&#xff0c;通过将复杂的任务拆分成多个简单的步骤&#xff0c;每一步都…...

深度学习 Deep Learning 第3章 概率论与信息论

第三章 概率与信息论 概述 本章介绍了概率论和信息论的基本概念及其在人工智能和机器学习中的应用。概率论为处理不确定性提供了数学框架&#xff0c;使我们能够量化不确定性和推导新的不确定陈述。信息论则进一步帮助我们量化概率分布中的不确定性。在人工智能中&#xff0c;…...

GStreamer —— 2.15、Windows下Qt加载GStreamer库后运行 - “播放教程 1:Playbin 使用“(附:完整源码)

运行效果 介绍 我们已经使用了这个元素&#xff0c;它能够构建一个完整的播放管道&#xff0c;而无需做太多工作。 本教程介绍如何进一步自定义&#xff0c;以防其默认值不适合我们的特定需求。将学习&#xff1a; • 如何确定文件包含多少个流&#xff0c;以及如何切换 其中。…...

MYsql—1

1.mysql的安装 在windows下安装mysql&#xff0c;直接官网搜索即可&#xff1a;http://www.mysql.com/&#xff0c;自己找想要的版本进行download&#xff0c;官网长这样 安装路径需要是英文路径&#xff0c;设置默认即可&#xff0c;若安装执行内容时报错&#xff0c;则AltCt…...

位运算(基础算法)

按位与AND&#xff08; & &#xff09; 只有当两个位都为1时&#xff0c;结果才为1,否则为0。结果不会变大 按位或 OR&#xff08; | &#xff09; 只有当两个位中有一个为1时&#xff0c;结果才为1,否则为0。结果不会变小 按位异或 XOR &#xff08; ^ &#xff09; 只…...

硬件地址反序?用位操作为LED灯序“纠偏”。反转二进制数即可解决

特别有意思&#xff0c;LED的灯序与其硬件地址刚好相反&#xff0c;没办法直接通过加1实现二进制进位的亮灯操作&#xff0c;查了一些资料说用数组和switch实现&#xff0c;觉得太麻烦了&#xff0c;思索良久&#xff0c;就想到了反转二进制数解决这个问题。 reverse_bits( )是…...

如何让ai问答机器人通人性?

领域专用的问答机器人&#xff0c;数据是灵魂。通用模型的问题在于&#xff0c;它们虽然知识广博&#xff0c;但对特定领域的深度理解不足。解决这个问题的第一步&#xff0c;就是构建一个高质量的领域知识库。 数据要精准且全面 想让机器人真正“懂”一个领域&#xff0c;数…...

AI绘画笔记--基础知识

一.什么是AI绘画 AI绘画或者说AI生图&#xff0c;本质上来说还是图像生成技术&#xff0c;是一种基于深度学习的人工智能技术&#xff0c;通过提前大量学习学习图像特征&#xff0c;生成符合提示词的新图像。 整个流程可以简化理解为&#xff1a;人们首先让深度学习模型读取大量…...

图解AUTOSAR_CP_BSWMulticoreLibrary

AUTOSAR BSW 多核库详解 AUTOSAR基础软件多核操作库详细解析 目录 架构概述 1.1. 组件架构 1.2. API结构 1.3. 错误处理流程详细设计 2.1. 基础数据类型 2.2. 接口说明 2.3. 错误处理机制使用指南 3.1. 配置说明 3.2. 典型应用场景 3.3. 注意事项 1. 架构概述 1.1. 组件架构 …...

热key探测技术架构设计与实践

参考&#xff1a; 得物热点探测技术架构设计与实践 Redis数据倾斜与JD开源hotkey源码分析揭秘 京东热点检测 HotKey 学习笔记 hotkey: 京东App后台中间件&#xff0c;毫秒级探测热点数据&#xff0c;毫秒级推送至服务器集群内存&#xff0c;大幅降低热key对数据层查询压力 …...

【微服务】java中http调用组件深入实战详解

目录 一、前言 二、http调用概述 2.1 什么是http调用 2.1.1 http调用步骤 2.2 HTTP调用特点 2.3 HTTP调用应用场景 三、微服务场景下http调用概述 3.1 微服务开发中http调用场景 3.2 微服务组件中http的应用 四、常用的http调用组件 4.1 java中常用的http组件介绍 4…...

Python数据结构 ——字典

1.以下关于Python字典变量的定义中,正确的是()。 A. d={[1,2]:1, [3,4]:3} B. d={1:as, 2:sf} C. d = {(1,2):1, (3,4):3} D. d={‘python’:1, 2:[tea, cat]} 答案:C。在Python中,字典是存储可变数量键值对的数据结构,通过字典类型实现映射,键必须是唯一的,必须是不可变数据…...

32、构造函数

1、用构造函数反复创建多个相同结果的对象 问题 如果想反复创建多个相同结构&#xff0c;但是内容不同的对象时&#xff0c;用{}创建会代码重复&#xff0c;及其不便于维护&#xff01; 解决 今后只要想反复创建同一类型的多个相同结构不同内容的对象时&#xff0c;都用构造函…...

编程环境搭建专栏目录汇总

1.WindowsvscodeclineMCP配置 2. Cline使用openrouter报错&#xff1a;Error Unexpected API Response: The language model did not provide any assista...

app.config.globalProperties

目录 一:基础使用 1、简介 2、使用 3、打印结果: 二:封装 1、创建一个.ts文件(utils/msg.ts) 2、在main.ts中全局注册 3、在页面中使用 4、打印结果 一:基础使用 1、简介 app.config.globalProperties 是 Vue 3 应用实例&#xff08;app&#xff09;的一个配置属性&…...

C# GeneticSharp包

可以直接从nuget安装GeneticSharp包 GeneticSharp 遗传算法类库 GeneticSharp 是什么 GeneticSharp 是一个C#的遗传算法类库, 遗传算法Java著名的JMetal, Python也有JMetalPy和PyMoo, C#相对差一截, 稍微有名的是GeneticSharp库. GeneticSharp 的弱点: 不支持多目标优化没…...

Leetcode做题记录----3

1474、删除链表M个节点之后的N个节点 思路&#xff1a; 1、两个循环解决问题 第一个循环移动M个位置&#xff0c;第二个循环确定移动N个位置后的&#xff0c;然后将M位置的节点的next指向&#xff0c;N位置后的节点即可 2、注意边界条件和判空处理 代码实现&#xff1a; pub…...

React(二):JSX语法解析+综合案例

事件绑定 this绑定方式 问题&#xff1a;在事件执行后&#xff0c;需获取当前类的对象中相关属性&#xff0c;此时需要this——当打印时&#xff0c;发现this为undefined,这又是为啥&#xff1f; 假设有一个btnClick函数&#xff0c;但它并不是我们主动调用的&#xff0c;而是…...

Gitee重新远程连接仓库(Linux)

Gitee重新远程连接仓库&#xff08;Linux&#xff09; 因为虚拟机重新安装了一回&#xff0c;所以需要重新和远程仓库连接&#xff0c;在网上找了很久没有找到相关操作&#xff0c;自己实操成功&#xff0c;记录下本博客&#xff0c;帮助有需要的人 确保新虚拟机安装Git 在新虚…...

Vitis HLS中的Array Partition与Array Reshape详解

Vitis HLS中的Array Partition与Array Reshape详解 引言 在高层次综合(HLS)设计中&#xff0c;数组是最常用的数据结构之一&#xff0c;但默认情况下&#xff0c;HLS会将数组映射到单个BRAM块&#xff0c;这会限制并行访问能力&#xff0c;成为性能瓶颈。为了克服这一限制&am…...

Centos离线安装openssl

文章目录 Centos离线安装openssl1. openssl是什么&#xff1f;2. openssl下载地址3. openssl-devel安装4. 安装结果验证5. 版本查看 Centos离线安装openssl 1. openssl是什么&#xff1f; OpenSSL 是一个开源的、跨平台的 加密工具库 和 命令行工具集&#xff0c;广泛用于实现…...

protobuf安装

安装 github官方链接 https://github.com/protocolbuffers/protobuf/ 以protobuf21为例 https://github.com/protocolbuffers/protobuf/releases/download/v21.11/protobuf-all-21.11.zip windows 解压好文件夹后,使用cmake,vs,qt creator等工具打开该项目,进行编译,编译需…...