CRD的全称为 CustomResourceDefinitions
,即自定义资源。k8s拥有一些内置的资源,比如说Pod,Deployment,ReplicaSet等等,而CRD则提供了一种方式,使用户可以自定义新的资源,以扩展k8s的功能。,使用CRD可以在不修改k8s源代码的基础上方便的扩展k8s的功能,比如腾讯云TKE使用CRD:logcollectors.ccs.cloud.tencent.com
以添加日志收集服务,而Istio也大量使用到了CRD。,值得一提的是,另一种扩展k8s的方式是apiservice,通过API:metrics.k8s.io自定义HPA是其最典型的应用。,可以使用kubectl api-resources
命令查看集群中已定义的资源:,从如上输出中可以略窥一二,CRD至少包括如下属性:,另外,CRD提供了定义资源的方式,不过想要让其具有实际意义还需控制器的配合。k8s的kube-controller-manager
组件提供了多种内置控制器,比如说:cronjob
,daemonset
,deployment
,namespace
等等,它们监听资源的创建/更新/删除,且做出相应的动作。而对于CRD来说,也可以编写相应的控制器来完成对应的功能。,在k8s中CRD本身也是资源,大于1.7.0版本的集群可以使用apiextensions.k8s.io/v1beta1API
访问CRD,大于1.16.0版本则可以使用apiextensions.k8s.io/v1API
。,创建CRD,CRD资源文件示例:,然后创建该CRD:,接着就能查到该CRD:,CRD创建完成。可以通过URL:https://169.254.128.15:60002/apis/staight.k8s.io/v1/namespaces/default/crontabs访问到crontab资源。,创建自定义对象,在创建CRD之后,即可创建其资源的对象了。资源文件示例:,注意spec中的字段应符合CRD的要求,创建它:,接着即可看到该对象:,CRD用来自定义资源,是扩展k8s最常用的方式。,只创建CRD并没有实际意义,想要CRD工作还需创建控制器,监听资源变动并做出相应动作。,