client-go controller-runtime和kubebuilder的区别
k8s 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)