摘要:可以通過(guò)驗(yàn)證自定義對(duì)象是否符合標(biāo)準(zhǔn)。此功能可用于及以上版本自定義資源。狀態(tài)和規(guī)范節(jié)分別由自定義資源內(nèi)的和表示。對(duì)子資源的請(qǐng)求采用自定義資源對(duì)象,并忽略除狀態(tài)節(jié)之外的任何更改。該對(duì)象作為有效負(fù)載發(fā)送。
kubernetes自定義資源對(duì)象高級(jí)功能
本文首發(fā)于微信公眾號(hào)“我的小碗湯”,掃碼文末二維碼即可關(guān)注,歡迎一起交流!
kubernetes自定義資源對(duì)象再極大程度提高了API Server的可擴(kuò)展性,讓企業(yè)能夠根據(jù)業(yè)務(wù)需求通過(guò)CRD編寫(xiě)controller或者operator來(lái)實(shí)現(xiàn)生產(chǎn)中各種特殊場(chǎng)景。隨著k8s的版本升級(jí),CRD的功能也越來(lái)越完善,下面對(duì)其中幾點(diǎn)進(jìn)行說(shuō)明。
以下驗(yàn)證kubernetes版本為1.13.2,docker版本:18.09.5
Validation(驗(yàn)證)在項(xiàng)目中用自定義資源對(duì)象時(shí),如果創(chuàng)建自定義資源時(shí)某些字段不符合要求,會(huì)導(dǎo)致監(jiān)聽(tīng)該資源對(duì)象的controller或者operator出現(xiàn)異常,解析結(jié)構(gòu)體報(bào)錯(cuò),所以Validation這個(gè)功能非常實(shí)用,在創(chuàng)建時(shí)就進(jìn)行校驗(yàn),減少后面的排錯(cuò)和異常處理的麻煩。
可以通過(guò) OpenAPI v3 schema驗(yàn)證自定義對(duì)象是否符合標(biāo)準(zhǔn) 。此外,以下限制適用于 schema:
字段default、nullable、discriminator、readOnly、writeOnly、xml、 deprecated 和 $ref 不能設(shè)置。
該字段 uniqueItems 不能設(shè)置為 true。
該字段 additionalProperties 不能設(shè)置為 false。
可以使用 kube-apiserverCustomResourceValidation 上的功能門(mén)(feature gate)禁用此功能:
--feature-gates=CustomResourceValidation=false
從以下特性門(mén)參數(shù)說(shuō)明地址,可以看到Validation功能在k8s 1.8版本就已經(jīng)有了,但是CustomResourceValidation特性門(mén)是默認(rèn)false,1.9Beta之后版本默認(rèn)為true
https://kubernetes.io/docs/re...
以下示例將大概對(duì)該功能進(jìn)行應(yīng)用和說(shuō)明,在以下示例中,CustomResourceDefinition 對(duì)自定義對(duì)象應(yīng)用以下驗(yàn)證:
spec.replicas 為必填項(xiàng),類(lèi)型為integer,值為大于等于0小于50的偶數(shù)(2的倍數(shù));
spec.repository 為必填項(xiàng);
spec.version為必填項(xiàng);
spec.pause為boolean類(lèi)型;
spec.updateStrategy為object類(lèi)型,該object中有type、pipeline、assignStrategies屬性;
spec.updateStrategy.type為string類(lèi)型,而且只能為"AssignReceive", "AutoReceive"兩個(gè)枚舉值;
spec.updateStrategy.pipeline為string類(lèi)型,而且為正整數(shù)的字符串,符合正則表達(dá)式^([1-9][0-9]*){1,3}$;
spec.updateStrategy.assignStrategies為array類(lèi)型,其元素為object類(lèi)型(包含slots和fromReplicas屬性);
spec.updateStrategy.assignStrategies.slots為1-16384的正整數(shù);
spec.updateStrategy.assignStrategies.fromReplicas為字符串,符合正則表達(dá)式^[a-z0-9,]{3,}$,即至少匹配3位a-z或者0-9或者逗號(hào)的字符串;
spec.pod為array類(lèi)型,其元素為object類(lèi)型(包含configmap、monitorImage、initImage、middlewareImage字段);
spec.pod.configmap、spec.pod.monitorImage、spec.pod.initImage 、spec.pod.middlewareImage為string類(lèi)型;且用required指定configmap、initImage、middlewareImage字段為必填項(xiàng)。
將以下內(nèi)容保存到 redis-cluster-crd.yaml:
apiVersion: apiextensions.k8s.io/v1beta1 kind: CustomResourceDefinition metadata: name: redisclusters.redis.middleware.hc.cn spec: group: redis.middleware.hc.cn versions: - name: v1alpha1 # Each version can be enabled/disabled by Served flag. served: true # One and only one version must be marked as the storage version. storage: true scope: Namespaced names: kind: RedisCluster singular: rediscluster listKind: RedisClusterList plural: redisclusters shortNames: - rec # 執(zhí)行kubectl get all時(shí)會(huì)查到pod、service、該crd等屬于all categories的資源對(duì)象 categories: - all validation: # openAPIV3Schema 適用于驗(yàn)證自定義對(duì)象的 schema。 openAPIV3Schema: properties: spec: required: ["replicas", "repository", "version"] properties: pause: type: boolean replicas: type: integer minimum: 0 maximum: 50 # 偶數(shù) multipleOf: 2 updateStrategy: type: object properties: type: type: string # 枚舉 enum: ["AssignReceive", "AutoReceive"] pipeline: type: string pattern: "^([1-9][0-9]*){1,3}$" assignStrategies: type: array items: type: object properties: slots: type: integer minimum: 1 maximum: 16384 fromReplicas: type: string # 至少匹配3位,a-z或者0-9或者, pattern: "^[a-z0-9,]{3,}$" pod: type: array items: type: object required: ["configmap", "middlewareImage", "initImage"] properties: configmap: type: string monitorImage: type: string initImage: type: string middlewareImage: type: string
創(chuàng)建它:
kubectl create -f redis-cluster-crd.yaml
默認(rèn)不加validation時(shí),在創(chuàng)建自定義資源對(duì)象時(shí),不會(huì)校驗(yàn),有些字段沒(méi)有了(如spec.replicas)都可以正常被創(chuàng)建,為了減少排錯(cuò)的難度和operator、controller的麻煩的檢驗(yàn),所以在創(chuàng)建自定義資源定義時(shí),就把validation加上。以上的檢驗(yàn)應(yīng)該覆蓋到了常見(jiàn)的檢驗(yàn)場(chǎng)景,其他場(chǎng)景可以自己摸索。具體還可以參考kubernetes源碼,1.13.2版本kubernetes源碼位于types.go第327行CustomResourceValidation結(jié)構(gòu)體:
$GOPATH/src/k8s.io/kubernetes/staging/src/k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/types.go
將以下YAML保存到redis-cluster-cr.yaml:
apiVersion: redis.middleware.hc.cn/v1alpha1 kind: RedisCluster metadata: name: example000-redis-cluster namespace: kube-system spec: # 代表redis集群的個(gè)數(shù) replicas: 3 # 代表是否進(jìn)入維修狀態(tài) pause: true repository: library/redis # 鏡像版本,便于后續(xù)多版本特化支持 version: 3.2.6 #redis集群升級(jí)策略 updateStrategy: # 升級(jí)類(lèi)型為AutoReceive(自動(dòng)分配,不用AssignStrategies), AssignReceive(指定值分配,需要用AssignStrategies) type: AssignReceive1 pipeline: "100a" assignStrategies: - slots: 0 fromReplicas: nodeId1 - # 從nodeId3,nodeId4一共分配1000個(gè)卡槽 slots: 1000 # 多個(gè)nodeId用逗號(hào)分隔 fromReplicas: nodeId3,nodeId4 # redis 實(shí)例配置詳情 pod: # 配置文件模板名 - configmap: example000-redis-cluster-config # 監(jiān)控鏡像 monitorImage: redis-exporter:v1 # 初始化鏡像 #initImage: redis-init:v1 # 中間件容器鏡像 middlewareImage: redis-trib:3.2.6
并創(chuàng)建它:
kubectl create -f redis-cluster-cr.yaml
會(huì)發(fā)現(xiàn)報(bào)以下錯(cuò)誤:
# kubectl apply -f redis-cluster-cr.yaml The RedisCluster "example000-redis-cluster" is invalid: []: Invalid value: map[string]interface {}{"apiVersion":"redis.middleware.hc.cn/v1alpha1", "kind":"RedisCluster", "metadata":map[string]interface {}{"namespace":"kube-system", "uid":"b0946031-766b-11e9-b457-000c295db389", "resourceVersion":"44231", "generation":19, "creationTimestamp":"2019-05-14T17:14:10Z", "annotations":map[string]interface {}{"kubectl.kubernetes.io/last-applied-configuration":"{"apiVersion":"redis.middleware.hc.cn/v1alpha1","kind":"RedisCluster","metadata":{"annotations":{},"name":"example000-redis-cluster","namespace":"kube-system"},"spec":{"pause":true,"pod":[{"configmap":"example000-redis-cluster-config","middlewareImage":"redis-trib:3.2.6","monitorImage":"redis-exporter:v1"}],"replicas":3,"repository":"library/redis","updateStrategy":{"assignStrategies":[{"fromReplicas":"nodeId1","slots":0},{"fromReplicas":"nodeId3,nodeId4","slots":1000}],"pipeline":"100a","type":"AssignReceive1"},"version":"3.2.6"}} "}, "name":"example000-redis-cluster"}, "spec":map[string]interface {}{"version":"3.2.6", "pause":true, "pod":[]interface {}{map[string]interface {}{"middlewareImage":"redis-trib:3.2.6", "monitorImage":"redis-exporter:v1", "configmap":"example000-redis-cluster-config"}}, "replicas":3, "repository":"library/redis", "updateStrategy":map[string]interface {}{"assignStrategies":[]interface {}{map[string]interface {}{"fromReplicas":"nodeId1", "slots":0}, map[string]interface {}{"fromReplicas":"nodeId3,nodeId4", "slots":1000}}, "pipeline":"100a", "type":"AssignReceive1"}}}: validation failure list: spec.updateStrategy.assignStrategies.fromReplicas in body should match "^[a-z0-9,]{3,}$" spec.updateStrategy.assignStrategies.slots in body should be greater than or equal to 1 spec.updateStrategy.pipeline in body should match "^([1-9][0-9]*){1,3}$" spec.updateStrategy.type in body should be one of [AssignReceive AutoReceive] spec.pod.initImage in body is required spec.replicas in body should be a multiple of 2
如果所有字段都符合校驗(yàn)邏輯,才可以創(chuàng)建對(duì)象。
將以下 YAML 保存到 redis-cluster-cr.yaml:
apiVersion: redis.middleware.hc.cn/v1alpha1 kind: RedisCluster metadata: name: example000-redis-cluster namespace: kube-system spec: # 代表redis集群的個(gè)數(shù) replicas: 6 # 代表是否進(jìn)入維修狀態(tài) pause: true repository: library/redis # 鏡像版本,便于后續(xù)多版本特化支持 version: 3.2.6 #redis集群升級(jí)策略 updateStrategy: # 升級(jí)類(lèi)型為AutoReceive(自動(dòng)分配,不用AssignStrategies), AssignReceive(指定值分配,需要用AssignStrategies) type: AssignReceive pipeline: "100" assignStrategies: - slots: 1 fromReplicas: all - # 從nodeId3,nodeId4一共分配1000個(gè)卡槽 slots: 1000 # 多個(gè)nodeId用逗號(hào)分隔 fromReplicas: node1,node2 # redis 實(shí)例配置詳情 pod: # 配置文件模板名 - configmap: example000-redis-cluster-config # 監(jiān)控鏡像 monitorImage: redis-exporter:v1 # 初始化鏡像 initImage: redis-init:v1 # 中間件容器鏡像 middlewareImage: redis-trib:3.2.6
并創(chuàng)建它,發(fā)現(xiàn)才可以創(chuàng)建:
# kubectl apply -f redis-cluster-cr.yaml rediscluster.redis.middleware.hc.cn/example000-redis-cluster configuredCategory(分類(lèi))
類(lèi)別是自定義資源所屬的分組資源的列表(例如 all)。您可以使用 kubectl get
以下示例添加 all CustomResourceDefinition 中的類(lèi)別列表,并說(shuō)明如何使用 kubectl get all 輸出自定義資源 。
將以下 內(nèi)容保存到 redis-cluster-crd.yaml中執(zhí)行kubectl apply -f redis-cluster-crd.yaml:
apiVersion: apiextensions.k8s.io/v1beta1 kind: CustomResourceDefinition metadata: name: redisclusters.redis.middleware.hc.cn spec: group: redis.middleware.hc.cn versions: - name: v1alpha1 # Each version can be enabled/disabled by Served flag. served: true # One and only one version must be marked as the storage version. storage: true scope: Namespaced names: kind: RedisCluster singular: rediscluster listKind: RedisClusterList plural: redisclusters shortNames: - rec # 執(zhí)行kubectl get all時(shí)會(huì)查到pod、service、該crd等屬于all categories的資源對(duì)象 categories: - all
將以下內(nèi)容保存到redis-cluster-cr.yaml中執(zhí)行kubectl apply -f redis-cluster-cr.yaml:
apiVersion: redis.middleware.hc.cn/v1alpha1 kind: RedisCluster metadata: name: example000-redis-cluster namespace: kube-system spec: # 代表redis集群的個(gè)數(shù) replicas: 6 # 代表是否進(jìn)入維修狀態(tài) pause: true repository: library/redis # 鏡像版本,便于后續(xù)多版本特化支持 version: 3.2.6 #redis集群升級(jí)策略 updateStrategy: # 升級(jí)類(lèi)型為AutoReceive(自動(dòng)分配,不用AssignStrategies), AssignReceive(指定值分配,需要用AssignStrategies) type: AssignReceive pipeline: "100" assignStrategies: - slots: 2000 fromReplicas: nodeId1 - # 從nodeId3,nodeId4一共分配1000個(gè)卡槽 slots: 1000 # 多個(gè)nodeId用逗號(hào)分隔 fromReplicas: nodeId3,nodeId4 # redis 實(shí)例配置詳情 pod: # 配置文件模板名 - configmap: example000-redis-cluster-config # 監(jiān)控鏡像 monitorImage: redis-exporter:v1 # 初始化鏡像 initImage: redis-init:v1 # 中間件容器鏡像 middlewareImage: redis-trib:3.2.6
執(zhí)行kubectl get all -nkube-system時(shí)會(huì)查到pod、service、該crd等屬于all categories的資源對(duì)象。(這個(gè)可能得等幾分鐘才能生效)
子資源 status子資源啟用狀態(tài)子資源后,將公開(kāi)自定義資源的子資源 /status。
狀態(tài)和規(guī)范節(jié)分別由自定義資源內(nèi)的 .status 和 .spec JSONPath 表示。
PUT /status 對(duì)子資源的請(qǐng)求采用自定義資源對(duì)象,并忽略除狀態(tài)節(jié)之外的任何更改。
PUT /status 對(duì)子資源的請(qǐng)求僅驗(yàn)證自定義資源的狀態(tài)節(jié)。
PUT/ POST/ PATCH 請(qǐng)求自定義資源忽略更改狀態(tài)節(jié)。
對(duì) spec 節(jié)的任何更改都會(huì)增加 .metadata.generation 的值。
在code-generator生成代碼時(shí)會(huì)生成,如下方法:
// RedisClusterInterface has methods to work with RedisCluster resources. type RedisClusterInterface interface { Create(*v1alpha1.RedisCluster) (*v1alpha1.RedisCluster, error) Update(*v1alpha1.RedisCluster) (*v1alpha1.RedisCluster, error) UpdateStatus(*v1alpha1.RedisCluster) (*v1alpha1.RedisCluster, error) ...... }scale子資源
啟用 scale 子資源后,將公開(kāi)自定義資源的子資源 /scale。該 autoscaling/v1.Scale 對(duì)象作為有效負(fù)載發(fā)送 /scale。
要啟用 scale 子資源,CustomResourceDefinition 中需要定義以下值。
SpecReplicasPath 在與之對(duì)應(yīng)的自定義資源中定義 JSONPath Scale.Spec.Replicas。這是一個(gè)必需的值。.spec 只允許使用帶點(diǎn)符號(hào)的 JSONPaths 。如果 SpecReplicasPath 自定義資源中沒(méi)有值,則 /scale 子資源將在GET上返回錯(cuò)誤。
StatusReplicasPath 在與之對(duì)應(yīng)的自定義資源中定義 JSONPath Scale.Status.Replicas。這是一個(gè)必需的值。.stutus 只允許使用帶點(diǎn)符號(hào)的 JSONPaths 。如果 StatusReplicasPath 自定義資源中沒(méi)有值,則子資源 /scale 中的狀態(tài)副本值將默認(rèn)為 0。
LabelSelectorPath在與之對(duì)應(yīng)的自定義資源中定義 JSONPath Scale.Status.Selector。這是一個(gè)可選值。必須將其設(shè)置為與 HPA 一起使用。.status 只允許使用帶點(diǎn)符號(hào)的 JSONPaths 。如果 LabelSelectorPath 自定義資源中沒(méi)有值,則子資源 /scale 中的狀態(tài)選擇器值將默認(rèn)為空字符串。
在以下示例中,啟用了status 和 scale 子資源。
將以下內(nèi)容保存到redis-cluster-crd.yaml并創(chuàng)建 kubectl apply -f redis-cluster-crd.yaml:
apiVersion: apiextensions.k8s.io/v1beta1 kind: CustomResourceDefinition metadata: name: redisclusters.redis.middleware.hc.cn spec: group: redis.middleware.hc.cn versions: - name: v1alpha1 # Each version can be enabled/disabled by Served flag. served: true # One and only one version must be marked as the storage version. storage: true scope: Namespaced names: kind: RedisCluster singular: rediscluster listKind: RedisClusterList plural: redisclusters shortNames: - rec # 執(zhí)行kubectl get all時(shí)會(huì)查到pod、service、該crd等屬于all categories的資源對(duì)象 categories: - all subresources: # status enables the status subresource. status: {} scale: # specReplicasPath defines the JSONPath inside of a custom resource that corresponds to Scale.Spec.Replicas. specReplicasPath: .spec.replicas # statusReplicasPath defines the JSONPath inside of a custom resource that corresponds to Scale.Status.Replicas. statusReplicasPath: .status.replicas # labelSelectorPath defines the JSONPath inside of a custom resource that corresponds to Scale.Status.Selector. labelSelectorPath: .status.labelSelector
創(chuàng)建 CustomResourceDefinition 對(duì)象后,您可以創(chuàng)建自定義對(duì)象。
如果您將以下 YAML 保存到 redis-cluster-cr.yaml:
apiVersion: redis.middleware.hc.cn/v1alpha1 kind: RedisCluster metadata: name: example000-redis-cluster namespace: kube-system spec: # 代表redis集群的個(gè)數(shù) replicas: 6 # 代表是否進(jìn)入維修狀態(tài) pause: true repository: library/redis # 鏡像版本,便于后續(xù)多版本特化支持 version: 3.2.6 #redis集群升級(jí)策略 updateStrategy: # 升級(jí)類(lèi)型為AutoReceive(自動(dòng)分配,不用AssignStrategies), AssignReceive(指定值分配,需要用AssignStrategies) type: AssignReceive pipeline: "100" assignStrategies: - slots: 2000 fromReplicas: nodeId1 - # 從nodeId3,nodeId4一共分配1000個(gè)卡槽 slots: 1000 # 多個(gè)nodeId用逗號(hào)分隔 fromReplicas: nodeId3,nodeId4 # redis 實(shí)例配置詳情 pod: # 配置文件模板名 - configmap: example000-redis-cluster-config # 監(jiān)控鏡像 monitorImage: redis-exporter:v1 # 初始化鏡像 initImage: redis-init:v1 # 中間件容器鏡像 middlewareImage: redis-trib:3.2.6
并創(chuàng)建它:
kubectl create -f redis-cluster-cr.yaml
然后在以下位置創(chuàng)建新的命名空間 RESTful API 端點(diǎn):
/apis/redis.middleware.hc.cn/v1alpha1/namespaces/kube-system/redisclusters/example000-redis-cluster/status
和
/apis/redis.middleware.hc.cn/v1alpha1/namespaces/kube-system/redisclusters/example000-redis-cluster/scale
可以使用該 kubectl scale 命令縮放自定義資源。例如,以上創(chuàng)建的自定義資源的的 .spec.replicas 設(shè)置為 10:
# kubectl get rec --all-namespaces NAMESPACE NAME DESIRED PAUSE AGE kube-system example000-redis-cluster 6 true 10h # kubectl scale --replicas=10 rec/example000-redis-cluster -nkube-system rediscluster.redis.middleware.hc.cn/example000-redis-cluster scaled # kubectl get rec --all-namespaces NAMESPACE NAME DESIRED PAUSE AGE kube-system example000-redis-cluster 10 true 10h # kubectl get rec example000-redis-cluster -n kube-system -o jsonpath="{.spec.replicas}" 10打印其他列
從 Kubernetes 1.11 開(kāi)始,kubectl 使用服務(wù)器端打印。服務(wù)器決定 kubectl get 命令顯示哪些列。您可以使用 CustomResourceDefinition 自定義這些列。下面的示例將輸出 Spec、Replicas 和 Age 列。
將 CustomResourceDefinition保存到 redis-cluster-crd.yaml。
apiVersion: apiextensions.k8s.io/v1beta1 kind: CustomResourceDefinition metadata: name: redisclusters.redis.middleware.hc.cn spec: group: redis.middleware.hc.cn versions: - name: v1alpha1 # Each version can be enabled/disabled by Served flag. served: true # One and only one version must be marked as the storage version.
scope: Namespaced names: kind: RedisCluster singular: rediscluster listKind: RedisClusterList plural: redisclusters shortNames: - rec # 執(zhí)行kubectl get all時(shí)會(huì)查到pod、service、該crd等屬于all categories的資源對(duì)象 categories: - all additionalPrinterColumns: - name: DESIRED type: integer description: The number of statefulset managed by the this redisCluster JSONPath: .spec.replicas # boolean,date,integer,number,string - name: PAUSE type: boolean description: Whether this redisCluster"s grandson (pod) will not be managed by statefulset JSONPath: .spec.pause
2. 創(chuàng)建 CustomResourceDefinition:
kubectl create -f redis-cluster-crd.yaml
3. 使用上面創(chuàng)建的 `redis-cluster-cr.yaml` 實(shí)例。 4. 調(diào)用服務(wù)器端打?。?
kubectl get rec --all-namespaces
請(qǐng)注意 `NAME`、`NAMESPACE`, `DESIRED`、`PAUSE` 和 `AGE` 在輸出列,并且都被轉(zhuǎn)成了大寫(xiě)字母:
[root@master-192 redis-container]# kubectl get rec --all-namespaces
NAMESPACE NAME DESIRED PAUSE AGE
kube-system example000-redis-cluster 6 true 10h
`NAME`和`NAMESPACE` 列是隱含的,不需要在 CustomResourceDefinition 中定義。 ## operator中應(yīng)用該特性 在golang編寫(xiě)的operator代碼中創(chuàng)建該結(jié)構(gòu)體:
//創(chuàng)建CRD
func CreateRedisClusterCRD(extensionCRClient *extensionsclient.Clientset) error {
//add CustomResourceValidation due to guarantee redis operator work normally labelSelectorPath := ".status.labelSelector" replicasMinimum := float64(0) replicasMaximum := float64(50) replicasMultipleOf := float64(2) slotsMinimum := float64(1) slotsMaximum := float64(16384) assignStr := "AssignReceive" autoStr := "AutoReceive" assignJson, _ := json.Marshal(assignStr) autoJson, _ := json.Marshal(autoStr) crd := &v1beta1.CustomResourceDefinition{ ObjectMeta: metav1.ObjectMeta{ Name: "redisclusters." + v1alpha1.SchemeGroupVersion.Group, }, Spec: v1beta1.CustomResourceDefinitionSpec{ Group: v1alpha1.SchemeGroupVersion.Group, Versions: []v1beta1.CustomResourceDefinitionVersion { { // Served is a flag enabling/disabling this version from being served via REST APIs Served: true, Name: v1alpha1.SchemeGroupVersion.Version, // Storage flags the version as storage version. There must be exactly one flagged as storage version Storage: true, }, }, Scope: v1beta1.NamespaceScoped, Names: v1beta1.CustomResourceDefinitionNames{ Kind: "RedisCluster", ListKind: "RedisClusterList", Plural: "redisclusters", Singular: "rediscluster", ShortNames: []string{"rec"}, Categories: []string{"all"}, }, Subresources: &v1beta1.CustomResourceSubresources { Status: &v1beta1.CustomResourceSubresourceStatus {}, Scale: &v1beta1.CustomResourceSubresourceScale { SpecReplicasPath: ".spec.replicas", StatusReplicasPath: ".status.replicas", LabelSelectorPath: &labelSelectorPath, }, }, AdditionalPrinterColumns: []v1beta1.CustomResourceColumnDefinition{ { Name: "DESIRED", Type: "integer", Description: "The number of statefulset managed by the this redisCluster", JSONPath: ".spec.replicas", }, { Name: "PAUSE", Type: "boolean", Description: "Whether this redisCluster"s grandson (pod) will not be managed by statefulset", JSONPath: ".spec.pause", }, { Name: "AGE", Type: "date", JSONPath: ".metadata.creationTimestamp", }, }, Validation: &v1beta1.CustomResourceValidation { OpenAPIV3Schema: &v1beta1.JSONSchemaProps { Properties: map[string]v1beta1.JSONSchemaProps { "spec": { Required: []string{"replicas", "repository", "version"}, Properties: map[string]v1beta1.JSONSchemaProps{ "pause": { Type: "boolean", }, "replicas": { Type: "integer", Minimum: &replicasMinimum, Maximum: &replicasMaximum, MultipleOf: &replicasMultipleOf, }, "updateStrategy": { Type: "object", Properties: map[string]v1beta1.JSONSchemaProps{ "type": { Type: "string", Enum: []v1beta1.JSON { { //這里必須是JSON格式的字符串 Raw: assignJson, }, { Raw: autoJson, }, }, }, "pipeline": { Type: "string", Pattern: `^([1-9][0-9]*){1,3}$`, }, "assignStrategies": { Type: "array", Items: &v1beta1.JSONSchemaPropsOrArray{ Schema: &v1beta1.JSONSchemaProps{ Type: "object", Properties: map[string]v1beta1.JSONSchemaProps{ "slots": { Type: "integer", Minimum: &slotsMinimum, Maximum: &slotsMaximum, }, "fromReplicas": { Type: "string", Pattern: `^[a-z0-9,]{3,}$`, }, }, }, }, }, }, }, }, }, "pod": { Type: "array", Items: &v1beta1.JSONSchemaPropsOrArray { Schema: &v1beta1.JSONSchemaProps { Type: "object", Required: []string{"replicas", "repository", "version"}, Properties: map[string]v1beta1.JSONSchemaProps{ "configmap": { Type: "string", }, "monitorImage": { Type: "string", }, "initImage": { Type: "string", }, "middlewareImage": { Type: "string", }, }, }, }, }, }, }, }, }, } _, err := extensionCRClient.ApiextensionsV1beta1().CustomResourceDefinitions().Create(crd) return err
}
## 參考 官方Extend the Kubernetes API with CustomResourceDefinitions: https://kubernetes.io/docs/tasks/access-kubernetes-api/custom-resources/custom-resource-definitions/ feature-gates參數(shù)說(shuō)明: https://kubernetes.io/docs/reference/command-line-tools-reference/feature-gates/ CustomResourceDefinition中文文檔: https://kubernetes.feisky.xyz/cha-jian-kuo-zhan/api/customresourcedefinition swagger和openAPI: 數(shù)據(jù)類(lèi)型: https://www.breakyizhan.com/swagger/2969.html 正則表達(dá)式: https://www.cnblogs.com/afarmer/archive/2011/08/29/2158860.html ---- --- 本公眾號(hào)免費(fèi)提供csdn下載服務(wù),海量IT學(xué)習(xí)資源,如果你準(zhǔn)備入IT坑,勵(lì)志成為優(yōu)秀的程序猿,那么這些資源很適合你,包括但不限于java、go、python、springcloud、elk、嵌入式 、大數(shù)據(jù)、面試資料、前端 等資源。同時(shí)我們組建了一個(gè)技術(shù)交流群,里面有很多大佬,會(huì)不定時(shí)分享技術(shù)文章,如果你想來(lái)一起學(xué)習(xí)提高,可以公眾號(hào)后臺(tái)回復(fù)【2】,免費(fèi)邀請(qǐng)加技術(shù)交流群互相學(xué)習(xí)提高,會(huì)不定期分享編程IT相關(guān)資源。 **掃碼關(guān)注,精彩內(nèi)容第一時(shí)間推給你**
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/27864.html
摘要:可以通過(guò)驗(yàn)證自定義對(duì)象是否符合標(biāo)準(zhǔn)。此功能可用于及以上版本自定義資源。狀態(tài)和規(guī)范節(jié)分別由自定義資源內(nèi)的和表示。對(duì)子資源的請(qǐng)求采用自定義資源對(duì)象,并忽略除狀態(tài)節(jié)之外的任何更改。該對(duì)象作為有效負(fù)載發(fā)送。 kubernetes自定義資源對(duì)象高級(jí)功能 本文首發(fā)于微信公眾號(hào)我的小碗湯,掃碼文末二維碼即可關(guān)注,歡迎一起交流! kubernetes自定義資源對(duì)象再極大程度提高了API Server的...
摘要:提供用于獲取有關(guān)容器和容器組狀態(tài)的實(shí)時(shí)信息的服務(wù),以及有關(guān)群集中開(kāi)發(fā)人員操作的詳細(xì)信息。集群最高級(jí)別的抽象是指運(yùn)行本身是集群應(yīng)用程序的一組機(jī)器及其管理的容器,一個(gè)集群必須有一個(gè),即命令和控制集群中所有其他機(jī)器的系統(tǒng)。Docker容器改變了人們對(duì)開(kāi)發(fā)、部署和維護(hù)軟件的思考方式,利用現(xiàn)代操作系統(tǒng)的本機(jī)隔離功能,容器支持類(lèi)似于虛擬機(jī)的關(guān)注點(diǎn)分離,但是與基于虛擬機(jī)監(jiān)控程序的虛擬機(jī)相比,它的開(kāi)銷(xiāo)要小得...
摘要:安全功能的最新引入是一組稱(chēng)為準(zhǔn)入控制器的插件。通過(guò)將標(biāo)志傳遞給服務(wù)器來(lái)配置啟用的準(zhǔn)入控制器集。本討論將僅關(guān)注基于的準(zhǔn)入控制器。摘要準(zhǔn)入控制器為安全性提供了顯著優(yōu)勢(shì)。 作者:Malte Isberner(StackRox) Kubernetes極大地提高了當(dāng)今生產(chǎn)中后端群集的速度和可管理性。由于其靈活性、可擴(kuò)展性和易用性,Kubernetes已成為容器編排器的事實(shí)標(biāo)準(zhǔn)。Kubernete...
摘要:安全功能的最新引入是一組稱(chēng)為準(zhǔn)入控制器的插件。通過(guò)將標(biāo)志傳遞給服務(wù)器來(lái)配置啟用的準(zhǔn)入控制器集。本討論將僅關(guān)注基于的準(zhǔn)入控制器。摘要準(zhǔn)入控制器為安全性提供了顯著優(yōu)勢(shì)。 作者:Malte Isberner(StackRox) Kubernetes極大地提高了當(dāng)今生產(chǎn)中后端群集的速度和可管理性。由于其靈活性、可擴(kuò)展性和易用性,Kubernetes已成為容器編排器的事實(shí)標(biāo)準(zhǔn)。Kubernete...
摘要:而用戶(hù)能在同一平臺(tái)上管理任何集群,輕松地充分利用的強(qiáng)大能力及其迅速壯大的生態(tài)系統(tǒng)。在本指南中,你將會(huì)了解如何快速上手。環(huán)境中的所有主機(jī)必須允許彼此間的流量能夠進(jìn)行跨主機(jī)聯(lián)網(wǎng)。這一過(guò)程需要幾分鐘完成。如果服務(wù)正常,將會(huì)顯示狀態(tài)為綠色。 大家好,給大家介紹一下,這是幫助大家率先上手嘗試Rancher 2.0的神器 @Rancher 2.0快速上手指南 內(nèi)容導(dǎo)讀 準(zhǔn)備一臺(tái)Linux主機(jī) 啟...
閱讀 736·2021-08-17 10:11
閱讀 1600·2019-08-30 11:15
閱讀 1025·2019-08-26 13:54
閱讀 3511·2019-08-26 11:47
閱讀 1224·2019-08-26 10:20
閱讀 2823·2019-08-23 18:35
閱讀 1219·2019-08-23 17:52
閱讀 1300·2019-08-23 16:19