Kubebuilder介绍:使用CRD构建Kubernetes API的SDK

Posted CNCF

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Kubebuilder介绍:使用CRD构建Kubernetes API的SDK相关的知识,希望对你有一定的参考价值。

Kubebuilder介绍:使用CRD构建Kubernetes API的SDK


我们如何才能让mysql、Spark和Cassandra这样的应用程序来管理自己,就像Kubernetes Deployments和Pods一样?我们如何配置这些应用程序为自己的第一类API,而不是StatefulSets、Services和ConfigMaps的集合?


我们一直致力于这个问题的解决方案,并很高兴推出kubebuilder。这是一个全面的开发工具包,使用CRD快速构建和发布Kubernetes API和控制器。Kubebuilder支持项目和API定义,基于controller-runtime库构建。


为什么使用Kubebuilder和Kubernetes API?


应用程序和群集资源通常需要一些操作,无论是使用新副本替换失败的副本,还是在重新分析数据时缩放副本数量。运行MySQL应用程序可能需要安排备份,在扩展后重新配置副本,设置故障检测和修复等。


使用Kubernetes API模型,管理逻辑直接嵌入到特定于应用程序的Kubernetes API中,例如,“MySQL”API。然后,用户使用kubectl等工具通过YAML配置声明性地管理应用程序,就像它们对Kubernetes对象一样。此方法称为应用程序控制器,也称为操作器(Operator)。控制器是支持核心Kubernetes API的强大技术,可用于构建除应用程序之外的多种解决方案,例如Autoscalers、Workload API、Configuration API、CI/CD系统等。


然而,虽然开发者可以在原始API机器之上构建新的控制器,这样做是一种“从零开始”的DIY经验,要求开发者学习有关如何实现Kubernetes库的低层细节,手写样板代码并且建自己的解决方案用于集成测试、RBAC配置、文档等。Kubebuilder通过应用从构建核心Kubernetes API中学到的经验,使这种体验变得简单容易。


构建应用程序控制器和Kubernetes API入门


通过提供创建控制器和Kubernetes API的结构化解决方案,开发者可以使用从开发核心Kubernetes API中学到的经验教训和最佳实践,获得“开箱即用”的体验。使用kubebuilder创建新的“Hello World”控制器非常简单:

- 创建项目:kubebuilder init

- 定义新的API:kubebuilder create api

- 构建并运行提供的main函数:make install & make run


这将生成API和Controller供用户修改,以及集成测试、RBAC规则、DockerfilesMakefile等。在实现代码写好添加到项目之后,用户创建工件通过以下方式发布他们的API:

- 从提供的Dockerfile构建并推送容器映像:make docker-build & make docker-push

- 部署API:make deploy


无论您已经是控制器的爱好者,还是只想了解是什么,请查看kubebuilder代码或查看kubebuilder书中的示例,以了解构建控制器可以是简单易用。


Kubebuilder是SIG API Machinery旗下的一个项目,由Google、Red Hat、VMware、华为等众多公司的贡献者积极开发。


网站/代码:

https://github.com/kubernetes-sigs/kubebuilder


文档:

https://book.kubebuilder.io/


即时交流:

Slack:http://slack.k8s.io/#kubebuilder


邮件列表:

kubebuilder(https://groups.google.com/forum/#!forum/kubebuilder)


订阅邮件列表,也可以发电邮到:

kubebuilder+subscribe@googlegroups.com




CNCF (Cloud Native Computing Foundation)成立于2015年12月,隶属于Linux  Foundation,是非营利性组织。 

云原生计算基金会(CNCF)致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。我们通过将最前沿的模式民主化,让这些创新为大众所用。请长按以下二维码进行关注。


以上是关于Kubebuilder介绍:使用CRD构建Kubernetes API的SDK的主要内容,如果未能解决你的问题,请参考以下文章

kubebuilder使用总结

kubebuilder 实战之开发一个存储用户信息的 operator

kubebuilder笔记

Kubebuilder 使用记录

使用kube-prometheus部署k8s监控

构建CRD工程 - 程序员学点xx 43 k8s