当前位置: 首页 > news >正文

k8s笔记——kubebuilder工作流程

kubebuilder工作流程


Kubebuilder 工作流程详解

Kubebuilder 是 Kubernetes 官方推荐的 Operator 开发框架,用于构建基于 Custom Resource Definitions (CRD) 的控制器。以下是其核心工作流程的完整说明:


1. 初始化项目

# 创建项目目录
mkdir my-operator && cd my-operator# 初始化 Kubebuilder 项目(指定 Go 模块名和 Kubernetes API 版本)
kubebuilder init --domain my.domain.com --repo my.domain.com/my-operator# 创建 API(定义 CRD 和控制器)
kubebuilder create api --group webapp --version v1 --kind Guestbook

作用

  • 生成项目脚手架代码
  • 配置 go.mod 和基础 Makefile
  • 创建 CRD 的 API 类型定义(api/v1/guestbook_types.go

2. 设计 CRD (Custom Resource)

编辑生成的 API 类型文件 api/v1/guestbook_types.go

type GuestbookSpec struct {// 定义用户可配置字段Message string `json:"message"`Replicas int32 `json:"replicas"`
}type GuestbookStatus struct {// 定义控制器维护的状态字段AvailableReplicas int32 `json:"availableReplicas"`
}

关键操作

  • 实现 runtime.Object 接口(Kubebuilder 已自动生成)
  • 通过 // +kubebuilder:subresource:status 等标记扩展功能

3. 生成 CRD 和代码

# 生成 CRD YAML 和 DeepCopy 方法
make manifests# 生成客户端代码(如 informers、listers)
make generate

输出结果

  • config/crd/bases/ 下的 CRD YAML 文件
  • zz_generated.deepcopy.go 自动生成的深拷贝代码

4. 实现控制器逻辑

编辑 controllers/guestbook_controller.go

func (r *GuestbookReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) {// 1. 获取 CR 实例guestbook := &webappv1.Guestbook{}if err := r.Get(ctx, req.NamespacedName, guestbook); err != nil {return ctrl.Result{}, client.IgnoreNotFound(err)}// 2. 业务逻辑(例如创建 Deployment)dep := &appsv1.Deployment{}if err := r.Get(ctx, req.NamespacedName, dep); err != nil {if errors.IsNotFound(err) {// 创建 Deploymentdep = r.newDeploymentForGuestbook(guestbook)if err := r.Create(ctx, dep); err != nil {return ctrl.Result{}, err}}}// 3. 更新状态guestbook.Status.AvailableReplicas = dep.Status.AvailableReplicasif err := r.Status().Update(ctx, guestbook); err != nil {return ctrl.Result{}, err}return ctrl.Result{}, nil
}

核心机制

  • Reconcile 循环:监听 CR 变化并触发调谐逻辑
  • 幂等性设计:确保重复执行不会产生副作用

5. 本地测试

# 安装 CRD 到集群
make install# 运行控制器(本地开发模式)
make run# 部署示例 CR
kubectl apply -f config/samples/webapp_v1_guestbook.yaml

调试工具

  • 使用 kubectl get guestbooks 查看自定义资源
  • 通过 kubectl logs 查看控制器日志

6. 构建与部署

# 构建镜像
make docker-build docker-push IMG=my-registry/my-operator:v1.0.0# 生成部署清单(RBAC、Deployment 等)
make manifests# 部署到集群
make deploy IMG=my-registry/my-operator:v1.0.0

生成内容

  • config/rbac/:角色权限配置
  • config/manager/:Operator 的 Deployment 配置

7. 高级功能扩展

Webhook 支持

# 创建 webhook
kubebuilder create webhook --group webapp --version v1 --kind Guestbook --defaulting --programmatic-validation

用途

  • 实现字段默认值注入(Mutating Webhook)
  • 验证字段合法性(Validating Webhook)

多版本 API 支持

通过 kubebuilder edit --multiversion 开启,生成版本转换逻辑。


工作流程图解

初始化项目
定义CRD
生成代码/CRD
实现控制器
本地测试
构建部署
扩展功能

关键设计理念

  1. 声明式 API:用户通过 YAML 描述期望状态,控制器负责实现
  2. 事件驱动:基于 Kubernetes 的 Informer 机制高效监听资源变更
  3. 水平扩展:控制器可多副本运行,通过 Leader Election 避免冲突

Kubebuilder 通过标准化的工作流程,显著降低了 Operator 的开发门槛,是构建 Kubernetes 原生扩展组件的首选工具。

http://www.xdnf.cn/news/263449.html

相关文章:

  • 嵌入式硬件篇---STM32F103C8T6STM32F103RCT6
  • Flink 的状态机制
  • Qt中实现工厂模式
  • 音视频开源项目列表
  • 【2025年】MySQL面试题总结
  • 实战探讨:为什么 Redis Zset 选择跳表?
  • xLua笔记
  • 55.[前端开发-前端工程化]Day02-包管理工具npm等
  • Oracle 11g通过dg4odbc配置dblink连接神通数据库
  • Oracle RAC ‘Metrics Global Cache Blocks Lost‘告警解决处理
  • 小程序滚动条隐藏(uniapp版本)
  • 【Java学习】通配符?
  • Java多语言DApp质押挖矿盗U源码(前端UniApp纯源码+后端Java)
  • 使用 Selenium 爬取动态网页数据 —— 实战与坑点详解
  • 基于LangChain 实现 Advanced RAG-后检索优化(下)-上下文压缩与过滤
  • 将Airtable导入NocoDB
  • 多协议 Tracker 系统架构与传感融合实战 第六章 多传感器时钟同步与数据对齐
  • SETNX的存在问题和redisson进行改进的原理
  • 【RAG】向量?知识库的底层原理:向量数据库の技术鉴赏 | HNSW(导航小世界)、LSH、K-means
  • 【Hive入门】Hive与Spark SQL深度集成:执行引擎性能全面对比与调优分析
  • C语言蓝桥杯真题代码
  • Go反射-通过反射调用结构体的方法(带入参)
  • 解决奥壹oelove婚恋原生小程序上架问题,彻底解决解对问题增强版旗舰版通用
  • 计算机网络八股文--day4 --传输层TCP与UDP
  • WebAPI项目从Newtonsoft.Json迁移到System.Text.Json踩坑备忘
  • 【项目实践】boost 搜索引擎
  • 基于 JSP 和 Servlet 的数字信息分析小应用
  • 【Linux】驱动开发方法
  • ES6/ES11知识点 续一
  • 人工智能发展史 — 物理学诺奖之 Hopfield 联想和记忆神经网络模型