使用statefulset的场景通常有以下特点:
- 有状态服务。
- 集群(多节点)部署。
- 节点有主从(备)之分。 集群通常是主节点先运行,从节点后续运行并加入集群,这里就用statefulset资源的有序部署的特性。
- 节点之间数据分片存储,这里使用到了statefulSet资源的存储隔离的特性,以及保证pod重新调度后还是能访问到相同的持久化数据。
注意
- 需要v1.5以上才支持。
- 所有pod的volume必须使用pv或者storageclass,需要事先创建好。
- 为来保证数据安全,删除statefulset时不会删除pvc。
- statefulset需要一个headless service,需要在statefulset之前创建好。
参考文章
1.StatefulSet在k8s的应用(Mysql)
StatefulSet 是 Kubernetes 中用于管理有状态应用的控制器,适用于需要稳定网络标识、稳定存储和有序部署、扩展及更新的场景。常见应用包括数据库(如 MySQL)、搜索引擎(如 Elasticsearch)和分布式服务注册发现(如 Eureka)。它确保了 Pod 的有序创建、删除,并提供了存储卷的持久化,确保数据安全。在使用 StatefulSet 时,需要配合 Headless Service,并且 Pod 的 Volume 需要预先配置。
2190

被折叠的 条评论
为什么被折叠?



