client-go controller-runtime和kubebuilder的区别

三者都是写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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值