client-go controller-runtime和kubebuilder的区别

文章探讨了在Kubernetes中编写自定义资源控制器时,使用client-go、controller-runtime和kubebuilder这三种方法的区别。client-go提供了缓存功能和informer机制,而controller-runtime和kubebuilder则进一步抽象,简化了开发流程,特别是kubebuilder通过自动化工具减少了手动定义和配置的工作。
摘要由CSDN通过智能技术生成

三者都是写operator的办法,client-go -> controller-runtime -> kubebuilder.

每一个都是上一层的一个封装。

client-go:提供缓存功能
informer: 接受apiserver通知,然后让缓存更新key-value,把消息入队

多个informer可以把数据放入一个controller的queue里

client-go 需要

在 golang 中定义 CRD 类型
生成深拷贝函数
生成 informer, lister, clientset
写控制循环
编写协调器逻辑
创建 informer、lister、clientset 供您的控制器使用
创建并运行你的控制器
执行与部署相关的步骤
您可以使用 controller-runtime 跳过上面的一些步骤。上面的列表缩减为

controller-runtime 需要

在 golang 中定义 CRD 类型
生成深拷贝函数
编写协调器逻辑
创建并运行你的控制器
执行与部署相关的步骤

kubebuilder 需要

在 golang 中定义 CRD 类型
编写协调器逻辑
创建并运行你的控制器

参考

https://vivilearns2code.github.io/k8s/2021/03/11/writing-controllers-for-kubernetes-custom-resources.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值