operator sdk和kubebuilder都是为了用户方便创建和管理operator而生的脚手架项目。对于用基于Golang开发的operator项目而言,operator sdk在底层使用了kubebuilder,例如operator sdk的命令行工具底层实际是调用kubebuilder的命令行工具。所以无论由operator sdk还是kubebuilder创建的operator项目都是调用的controller-runtime接口,而有相同的项目布局。
├── api
│ └── v1alpha1
├── bin
│ ├── controller-gen
│ ├── kustomize
│ ├── manager
│ └── opm
├── config
│ ├── crd
│ ├── default
│ ├── manager
│ ├── manifests
│ ├── prometheus
│ ├── rbac
│ ├── samples
│ └── scorecard
├── controllers
│ ├── suite_test.go
│ └── znbasecluster_controller.go
├── Dockerfile
├── go.mod
├── go.sum
├── hack
│ └── boilerplate.go.txt
├── main.go
├── Makefile
├── PROJECT
└── testbin
└── setup-envtest.sh
除此以外,operator sdk还增加了一些特性。默认情况下,使用operator-sdk init生成的项目集成如下功能:
另外,operator sdk除了支持golang以外,还支持Ansible和Helm。
总结:
如果你在两者之间犹豫不决,建议还是选择sdk吧。
更详细的信息请参考:
https://sdk.operatorframework.io/docs/faqs/
https://www.openshift.com/blog/operator-sdk-reaches-v1.0