文章目录

  • statefulset控制器简介
  • statefulset控制器如何通过headless service维持pod的状态
  • pv和pvc的设计,使得statefulset能管理存储状态
  • 使用statefulset部署MySQL主从复制集群



使用阿里云主机ECS,
四台主机信息如下:
server1 — 私网IP:10.0.0.2 ----公网IP: 47.108.54.185 ---- 搭建docker仓库harbor—nfs服务器
server2 — 私网IP:10.0.0.3 ----公网IP: 47.108.144.231 ---- k8s集群主节点
server3 — 私网IP:10.0.0.4 ----公网IP: 47.108.115.206 ---- k8s集群节点
server4 — 私网IP:10.0.0.5 ----公网IP: 47.108.28.42 ---- k8s集群节点


statefulset控制器简介

  • StatefulSet是用来管理有状态应用的工作负载API对象,实例之间有不对等关系,以及实例对外部数据有依赖关系的应用,称为“有状态应用”
  • StatefulSet将应用状态抽象成了两种情况:
    拓扑状态:应用实例必须按照某种顺序启动。新创建的Pod必须和原来Pod的网络标识一样
    存储状态:应用的多个实例分别绑定了不同存储数据。
  • StatefulSet通过Headless Service维持Pod的拓扑状态
  • StatefulSet给所有的Pod进行了编号,编号规则是: $(statefulset名称)−(序号),从0开始。
  • StatefulSet还会为每一个Pod分配并创建一个同样编号的PVC。这样,kubernetes就可以通过Persistent Volume机制为这个PVC绑定对应的PV,从而保证每一个Pod都拥有一个独立的Volume。
  • Pod被删除后重建,重建Pod的网络标识也不会改变,Pod的拓扑状态按照Pod的“名字+编号”的方式固定下来,并且为每个Pod提供了一个固定且唯一的访问入口,即Pod对应的DNS记录。

statefulset控制器如何通过headless service维持pod的状态

k8s指定容器ip k8s statefulset 固定ip_kubernetes

k8s指定容器ip k8s statefulset 固定ip_kubernetes_02


k8s指定容器ip k8s statefulset 固定ip_运维_03


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_04


k8s指定容器ip k8s statefulset 固定ip_docker_05


k8s指定容器ip k8s statefulset 固定ip_docker_06


k8s指定容器ip k8s statefulset 固定ip_运维_07


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_08

pv和pvc的设计,使得statefulset能管理存储状态

k8s指定容器ip k8s statefulset 固定ip_docker_09


k8s指定容器ip k8s statefulset 固定ip_kubernetes_10


Statefulset还会为每一个pod分配并创建一个同样编号的pvc。

这样,kubernetes就可以通过PV机制绑定对应的PVC,从而保证每一个pod都拥有一个独立的卷

k8s指定容器ip k8s statefulset 固定ip_Pod_11


k8s指定容器ip k8s statefulset 固定ip_运维_12


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_13


k8s指定容器ip k8s statefulset 固定ip_运维_14

使用statefulset部署MySQL主从复制集群

参考官方文档:
https://kubernetes.io/zh-cn/docs/tasks/run-application/run-replicated-stateful-application/

包含的模块:
MySQL集群包含一个CM,两个Service与一个StatefulSet
配置Mysql主从时,不同的节点的配置不同。
CM中包含两个配置文件,分别为主配置文件:master.cnf和从配置文件:slave.cnf
主要包含两个SVC:Headless Service和ClusterIP Service;Headless SVC主要负责主集群

k8s指定容器ip k8s statefulset 固定ip_kubernetes_15


k8s指定容器ip k8s statefulset 固定ip_运维_16


编辑CM,主服务器可以将日志提供给从服务器,并且从服务器只能读不能写:

注意:由于这里的数据目录与statefulset.yaml文件中的数据目录写的不一致,导致后面pod起不来,注意避开这个错误。

写成默认路径:

datadir=/var/lib/mysql 或者不写,也代表使用默认路径。

k8s指定容器ip k8s statefulset 固定ip_运维_17


k8s指定容器ip k8s statefulset 固定ip_docker_18

接下来,创建两个SVC:

k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_19


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_20

创建statefulset控制器。

  • 首先使用无头服务,初始化容器,使用mysql镜像,利用脚本分别拿到主从配置文件,对启动的Pod生成server id的文件(server-id.cnf),再将CM的配置文件按主从类型拷贝出来(通过上一部主机id来决定)
  • 接下来启动的副本允许超户使用空密码;挂载了两个目录,包含配置目录和数据目录;分别可以使用CPU一半的资源和使用1G内存,并添加了存活探针和就绪探针
  • 在容器最后需要声明挂载卷的类型,conf为空卷,config-map是挂载卷

直接复制官方文档。

k8s指定容器ip k8s statefulset 固定ip_docker_21

k8s指定容器ip k8s statefulset 固定ip_Pod_22

k8s指定容器ip k8s statefulset 固定ip_运维_23


k8s指定容器ip k8s statefulset 固定ip_kubernetes_24


k8s指定容器ip k8s statefulset 固定ip_运维_25


准备mysql备份工具:xtrabackup,并上传至harbor仓库

k8s指定容器ip k8s statefulset 固定ip_kubernetes_26


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_27


k8s指定容器ip k8s statefulset 固定ip_docker_28

k8s指定容器ip k8s statefulset 固定ip_docker_29

k8s指定容器ip k8s statefulset 固定ip_Pod_30

k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_31

k8s指定容器ip k8s statefulset 固定ip_运维_32


k8s指定容器ip k8s statefulset 固定ip_kubernetes_33


k8s指定容器ip k8s statefulset 固定ip_docker_34


k8s指定容器ip k8s statefulset 固定ip_Pod_35


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_36


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_37


k8s指定容器ip k8s statefulset 固定ip_Pod_38


k8s指定容器ip k8s statefulset 固定ip_Pod_39


k8s指定容器ip k8s statefulset 固定ip_运维_40


k8s指定容器ip k8s statefulset 固定ip_docker_41


k8s指定容器ip k8s statefulset 固定ip_docker_42


k8s指定容器ip k8s statefulset 固定ip_Pod_43


k8s指定容器ip k8s statefulset 固定ip_Pod_44


k8s指定容器ip k8s statefulset 固定ip_docker_45


k8s指定容器ip k8s statefulset 固定ip_k8s指定容器ip_46


k8s指定容器ip k8s statefulset 固定ip_kubernetes_47


k8s指定容器ip k8s statefulset 固定ip_docker_48


实验完毕,还原。

k8s指定容器ip k8s statefulset 固定ip_docker_49


k8s指定容器ip k8s statefulset 固定ip_docker_50