文章目录
前言
上一篇我们主要介绍了如何通过K8S的PV和PVC机制来实现mysql的持久化部署,然后我们发现一个问题,当我们需要不中断业务升级或者启动多个应用处理业务的时候,需要创建多个带mysql应用的pod,此时却只有一个能够正常启动,因为它们访问的是同一份mysql数据。为了解决此类需求,K8S提供了一种有状态部署的方式StatefulSet。本篇我们重点探讨mysql应用的StatefulSet部署。
一、StatefulSet
之前我们一直使用Deployment作为应用编排管理的工具,它的特点是无状态管理,意思是它所管理的pod都是一模一样的副本,所有pod的应用、行为都是完全相同的。
对于有状态应用的需求,K8S提供了StatefulSet来管理(当然StatefulSet也可以用来管理无状态应用)。StatefulSet与Deployment的区别有以下几点:
1、StatefulSet创建的pod都是有序号的,从0开始递增。
2、StatefulSet可以通过PVC模板,使每个pod都有一块独立的PV存储。
3、Deployment由Rs来管理pod,而StatefulSet直接管理pod。
二、sts部署mysql应用
1、编写mysql-sts.yaml文件如下:
apiVersion: apps/v1 #版本
kind: StatefulSet