共计 1814 个字符,预计需要花费 5 分钟才能阅读完成。
高日耀 资深数据库内核研发
毕业于华中科技大学,喜爱钻研支流数据库架构和源码,并长期从事分布式数据库内核研发。曾参加分布式 MPP 数据库 CirroData 内核开发(西方国信),现次要负责 MySQL 系列产品内核开发(青云科技)。
本文是 MySQL Operator 设计第二篇,上一篇 介绍了 MySQL Operator 架构概览和设计思路。这一期将介绍 Operator 脚手架选型和工程创立过程。
| Operator 脚手架选型
建筑工地在建设房子的时候,最开始都要搭建一个脚手架,便于更快更平安的施工造房子。同样,Operator 工程的构建也要搭建一个脚手架,不便后续疾速的开发和迭代,而 Kubernetes 社区有很多成熟的构建脚手架的工具供咱们抉择。
脚手架构建工具
- Operator 框架 SDK:https://operatorframework.io/
- Kubebuilder:https://book.kubebuilder.io/
- KUDO(Kubernetes 通用申明式 Operator):https://kudo.dev/
- Charmed Operator 框架 :https://juju.is/
目前社区活跃度和使用率最高的是 Operator SDK 和 Kubebuilder。它们都应用官网的 controller-tools 和 controller-runtime,有雷同的布局,不同点在于:
Kubebuilder
- 蕴含 envtest 包,容许 Operator 开发人员应用独立的 etcd 和 apiserver 运行简略的测试
- 主动生成 Makefile 以帮忙用户执行 Operator 工作(构建、测试、运行、代码生成等)
- 应用 kustomize 构建部署清单
- 改良了对准入和 CRD 转换 WebHooks 的反对
Operator SDK
- 更好的反对 Ansible 和 Helm operator 这类下层操作
- 与 Operator LifecycleManager(OLM) 的集成,OLM 是 Operator Framework 的一个要害组件,对于第 2 天集群操作十分重要,比方治理 Operator 实时降级
- 蕴含记分卡子命令,它能够帮忙您了解 Operator 是否遵循最佳实际
- 包含 e2e 测试框架,它简化了对理论集群测试操作的过程
目前两个社区逐步在交融,Operator SDK 也在一直向 Kubebuilder 聚拢,因而咱们抉择更原生、更嫡系的 Kubebuilder (目前到了 3.0 版本) 作为 Operator 工程的脚手架。
| 创立工程
初始化 Operator 和 Controller API
Kubebuilder 为 Operator 代码库中波及的各种组件(如 CRD 和 Controller-API)的代码生成提供了疾速教程和简略的脚手架,其架构如下所示:
创立步骤
按以下两个步骤创立工程:
1. 初始化 Operator 工程
初始化域名设置为 radondb.com,将主动生成了镜像制作脚本,Makefile,配置文件以及 main.go。指令如下:
kubebuilder init --domain=radondb.com
2. 创立 Controller
API、GVK(group, version, kind) 别离指定为 mysql, v1alpha1, MysqlCluster。
controller 参数设置为 true 意思是主动生成控制器初始的代码文件。指令如下:
kubebuilder create api --group mysql --version v1alpha1 --kind MysqlCluster --resource=true --controller=true
通过两条指令生成的文件目录比照,执行第二条指令后,多了 api 目录,crd 目录以及 controllers 目录。
Project Layout 概览
以下为 radondb-mysql-kubernetes 我的项目的当前目录构造及性能介绍。
| 总结
Operator 基于 Kubernetes 的资源和控制器概念之上构建,同时又蕴含了应用程序特定的畛域常识。创立 Operator 的要害是 CRD(自定义资源)的设计。下一篇咱们将解析 radondb-mysql-kubernetes 我的项目中自定义 CRD 的设计。
相干浏览
- 在 Kubernetes 上部署 RadonDB MySQL 集群
- 基于 K8s 的新一代 MySQL 高可用架构实现计划
- RadonDB MySQL on K8s 2.1.0 公布!
- MySQL Operator 01 | 架构设计概览