容器化基于Kubernetes的新⼀代MySQL⾼可⽤架构实现⽅案
作者:⾼⽇耀资深 MySQL 内核研发
本⽂源于作者在 KubeSphere & Friends 2021 杭州站的演讲内容《基于 Kubernetes 的新⼀代 MySQL ⾼可⽤架构实现⽅案》。
本⽂是 MySQL 容器化系列的第三篇⽂章,主要介绍 MySQL 容器化 Helm 版本[1] 的设计思路。
Dockerfile 简介我很好
⾸先 RadonDB MySQL ⼀个 Pod 中的容器⾓⾊中,⼀般包含 MySQL、Xenon、slowlog 三个容器。
其中,MySQL 和 Xenon Dockerfile ⽬录结构如下所⽰:
MySQL Dockerfile 解析
启动 MySQL 主进程前,需要准备数据库配置、初始化等,这些⼯作要在最终的 MySQL 运⾏之前解决。在制作镜像时,通过配置 MySQL Dockerfile 中ENTRYPOINT和CMD参数,可提前准备数据库配置
、初始化等进程。
Docker 是分层的,每⼀条命令都会建⼀个镜像层,分层太多会导致快速膨胀。在制作镜像时,不建议分层太多。
MySQL Dockerfile⽂件中命令⽰例如下:
MySQL mysql-entry.sh⽂件中包含启动命令,其主要执⾏流程如下:
Xenon Dockerfile 解析
Xenon Dockerfile ⽐较简单,跟 MySQL Dockerfile 流程类似。
Xenon Dockerfile命令⽰例如下:
森林防火的内容xenon-entry.sh主要功能:
1. ⽣成 Xenon 配置⽂件,在 Xenon 启动的时候调⽤
2. ping host
name ⽣成及环境变量
name ⽣成
陈昭羽
⾸先我们看下 chart ⽬录下功能⽂件列表,chart 下包含的⽂件如下图所⽰:
其中,_helpers.tpl常需引⽤Chart.yaml和values.yaml中定义的变量,继⽽实现如下能⼒:
⽣成 app 名字:helm install relea <;版本名,如 emo> <;项⽬名,如radondb-mysql>
⽣成rviceAccountName名字。
⽣成 chart 名字和版本。
通过命令helm get all demo,可查看 demo 中所有信息。查看 rvice 部分 name ⽰例如下:
104 # Source: radondb-mysql/templates/rviceaccount.yaml
105 apiVersion: v1
106 kind: ServiceAccount
后台应用107 metadata:
108 name: demo-radondb-mysql
109 labels:
110 app: demo-radondb-mysql
111 chart: radondb-mysql-1.0.0
112 relea: "demo"
113 heritage: "Helm"
环境变量
环境变量主要⽬的是保存密码和配置参数解耦。
crets.yaml 功能
Opaque
ba64 转码
加密插件
configmap.yaml 功能
将配置参数和 docker 镜像解耦
保存⼀些配置参数和修改 lable 的脚本
如何识别集群中 leader、follower ⾓⾊?
识别集群节点⾓⾊,需创建⼀个服务账号,并授予相应的权限。通过执⾏在config⽂件中保存的脚本,调⽤相应的 API 来修改对应⾓⾊的lable。
节点⾓⾊修改后,相应 lable 效果如下。此时,通过服务标签后缀,即可轻松辨别 Leader 和 Follower ⾓⾊的节点。
在 KubeSphere[2] 管理控制台,可查看到⾓⾊修改后⽰例如下:
如何实现读写分离?
RadonDB MySQL 读写分离,通过 Headless rvice for stable DNS [3] 来实现。
分配⼀个集群内部可以访问的虚拟 IP (VIP),VIP 是固定的,⽽节点所绑定的 Pod 的 IP 是可以变化的,每个 Node 上分配⼀个端⼝作为外部访问⼊⼝。以此特点,可以设定⼀个读 IP 和⼀个写 IP,来达到读写分离的⽬的,⽽⽆需担⼼新绑定 Pod 致使 IP 发⽣变化。
以 Leader 节点为例,下图所⽰的 ClusterIP 对应写 IP(10.111.92.63),其绑定当前的 Pod(主)IP 为172.17.0.10。
邂逅 KubeShpere
RadonDB MySQL 已经登录 KubeSphere 应⽤商店(3.1.0 版本推出),可以通过 KubeSphere 来实现对集群的查看和管理。
处女座幸运色1、通过终端查看集群正常时 gtid 和对应的状态
2、模拟 Follower 节点挂掉场景
kill 掉名为 demo-radondb-mysql-2 的 follower:
从另外⼀个节点登⼊终端再次查看集群状态,该 follower 节点 MySQL 和 IO/SQL 状态都不正常。
从 KubeSphere 界⾯查看:
男人为什么长胡子
挂掉的节点重新拉起,集群开始重新发起选举:
3、Leader (demo-radondb-mysql-0)节点挂掉场景
leader 降级为 follower,原来另外两个从节点进⼊候选者状态:
中午问候语温馨一句话从 KubeSphere 界⾯查看,这时已经查不到 leader pod:
等待⼀段时间,集群选出新主(demo-radondb-mysql-2):
从 KubeSphere 看到原来的主(demo-radondb-mysql-0)变为 follower:
互联网事件营销
4、⽹络隔离
将新主(demo-radondb-mysql-2) 隔离。
等待⼀段时间,可以看到新主(demo-radondb-mysql-0)重新被选出:
关于 RadonDB
RadonDB 开源社区是⼀个⾯向云原⽣、容器化的数据库开源社区,为数据库技术爱好者提供围绕主流开源数据库(MySQL、PostgreSQL、Redis、MongoDB、ClickHou 等)的技术分享平台,并提供企业级 RadonDB 开源产品及服务。
⽬前 RadonDB 开源数据库系列产品已被光⼤银⾏、浦发硅⾕银⾏、哈密银⾏、泰康保险、太平保险、安盛保险、阳光保险、百年⼈寿、安吉物流、安畅物流、蓝⽉亮、天财商龙、罗克佳华、升哲科技、⽆锡汇跑体育、北京电信、江苏交通控股、四川航空、昆明航空、国控⽣物等上千家企业及社区⽤户采⽤。
RadonDB 可基于云平台与 Kubernetes 容器平台交付,不仅提供覆盖多场景的数据库产品解决⽅案,⽽且提供专业的集群管理和⾃动化运维能⼒,主要功能特性包括:⾼可⽤主从切换、数据强⼀致性、读写分离、⼀键安装部署、多维指标监控&告警、弹性扩容&缩容、横向⾃由扩展、⾃动备份&恢复、同城多活、异地灾备等。RadonDB 仅需企业及社区⽤户专注于业务层逻辑开发,⽆需关注集群⾼可⽤选型、管理和运维等复杂问题,帮助企业及社区⽤户⼤幅度提升业务开发与价值创新的效率!
GitHub:
微信群:请搜索添加群助⼿微信号 radondb