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