K8s中的StatefulSet应用

StatefulSet 是 Kubernetes 中用于管理有状态应用的控制器,适用于需要稳定网络标识、稳定存储和有序部署、扩展及更新的场景。常见应用包括数据库(如 MySQL)、搜索引擎(如 Elasticsearch)和分布式服务注册发现(如 Eureka)。它确保了 Pod 的有序创建、删除,并提供了存储卷的持久化,确保数据安全。在使用 StatefulSet 时,需要配合 Headless Service,并且 Pod 的 Volume 需要预先配置。

使用statefulset的场景通常有以下特点:

  • 有状态服务。
  • 集群(多节点)部署。
  • 节点有主从(备)之分。 集群通常是主节点先运行,从节点后续运行并加入集群,这里就用statefulset资源的有序部署的特性。
  • 节点之间数据分片存储,这里使用到了statefulSet资源的存储隔离的特性,以及保证pod重新调度后还是能访问到相同的持久化数据。

注意

  • 需要v1.5以上才支持。
  • 所有pod的volume必须使用pv或者storageclass,需要事先创建好。
  • 为来保证数据安全,删除statefulset时不会删除pvc。
  • statefulset需要一个headless service,需要在statefulset之前创建好。

参考文章

1.StatefulSet在k8s的应用(Mysql)

2. StatefulSet在K8s的应用(Elastic Search)

3. 在K8S环境下用statefulset+headless service 搭建eureka集群 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值