成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

kubernetes自定義資源對(duì)象高級(jí)功能

陳江龍 / 2313人閱讀

摘要:可以通過驗(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ù)需求通過CRD編寫controller或者operator來實(shí)現(xiàn)生產(chǎn)中各種特殊場景。隨著k8s的版本升級(jí),CRD的功能也越來越完善,下面對(duì)其中幾點(diǎn)進(jìn)行說明。

以下驗(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)聽該資源對(duì)象的controller或者operator出現(xiàn)異常,解析結(jié)構(gòu)體報(bào)錯(cuò),所以Validation這個(gè)功能非常實(shí)用,在創(chuàng)建時(shí)就進(jìn)行校驗(yàn),減少后面的排錯(cuò)和異常處理的麻煩。

可以通過 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 上的功能門(feature gate)禁用此功能:

--feature-gates=CustomResourceValidation=false

從以下特性門參數(shù)說明地址,可以看到Validation功能在k8s 1.8版本就已經(jīng)有了,但是CustomResourceValidation特性門是默認(rèn)false,1.9Beta之后版本默認(rèn)為true

https://kubernetes.io/docs/re...

以下示例將大概對(duì)該功能進(jìn)行應(yīng)用和說明,在以下示例中,CustomResourceDefinition 對(duì)自定義對(duì)象應(yīng)用以下驗(yàn)證:

spec.replicas 為必填項(xiàng),類型為integer,值為大于等于0小于50的偶數(shù)(2的倍數(shù));

spec.repository 為必填項(xiàng);

spec.version為必填項(xiàng);

spec.pause為boolean類型;

spec.updateStrategy為object類型,該object中有type、pipeline、assignStrategies屬性;

spec.updateStrategy.type為string類型,而且只能為"AssignReceive", "AutoReceive"兩個(gè)枚舉值;

spec.updateStrategy.pipeline為string類型,而且為正整數(shù)的字符串,符合正則表達(dá)式^([1-9][0-9]*){1,3}$;

spec.updateStrategy.assignStrategies為array類型,其元素為object類型(包含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類型,其元素為object類型(包含configmap、monitorImage、initImage、middlewareImage字段);

spec.pod.configmap、spec.pod.monitorImage、spec.pod.initImagespec.pod.middlewareImage為string類型;且用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),有些字段沒有了(如spec.replicas)都可以正常被創(chuàng)建,為了減少排錯(cuò)的難度和operator、controller的麻煩的檢驗(yàn),所以在創(chuàng)建自定義資源定義時(shí),就把validation加上。以上的檢驗(yàn)應(yīng)該覆蓋到了常見的檢驗(yàn)場景,其他場景可以自己摸索。具體還可以參考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í)類型為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í)類型為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 configured
Category(分類)

類別是自定義資源所屬的分組資源的列表(例如 all)。您可以使用 kubectl get 列出屬于該類別的資源。此功能可用于 v1.10 及以上k8s版本自定義資源。

以下示例添加 all CustomResourceDefinition 中的類別列表,并說明如何使用 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í)類型為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)子資源后,將公開自定義資源的子資源 /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 子資源后,將公開自定義資源的子資源 /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 自定義資源中沒有值,則 /scale 子資源將在GET上返回錯(cuò)誤。

StatusReplicasPath 在與之對(duì)應(yīng)的自定義資源中定義 JSONPath Scale.Status.Replicas。這是一個(gè)必需的值。.stutus 只允許使用帶點(diǎn)符號(hào)的 JSONPaths 。如果 StatusReplicasPath 自定義資源中沒有值,則子資源 /scale 中的狀態(tài)副本值將默認(rèn)為 0。

LabelSelectorPath在與之對(duì)應(yīng)的自定義資源中定義 JSONPath Scale.Status.Selector。這是一個(gè)可選值。必須將其設(shè)置為與 HPA 一起使用。.status 只允許使用帶點(diǎn)符號(hào)的 JSONPaths 。如果 LabelSelectorPath 自定義資源中沒有值,則子資源 /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í)類型為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 開始,kubectl 使用服務(wù)器端打印。服務(wù)器決定 kubectl get 命令顯示哪些列。您可以使用 CustomResourceDefinition 自定義這些列。下面的示例將輸出 Spec、ReplicasAge 列。

將 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)成了大寫字母:

[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編寫的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ù)說明:

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ù)類型:

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ù)文章,如果你想來一起學(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/32980.html

相關(guān)文章

  • kubernetes定義資源對(duì)象高級(jí)功能

    摘要:可以通過驗(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的...

    Mr_zhang 評(píng)論0 收藏0
  • 來說說Kubernetes的運(yùn)作機(jī)制

    摘要:提供用于獲取有關(guān)容器和容器組狀態(tài)的實(shí)時(shí)信息的服務(wù),以及有關(guān)群集中開發(fā)人員操作的詳細(xì)信息。集群最高級(jí)別的抽象是指運(yùn)行本身是集群應(yīng)用程序的一組機(jī)器及其管理的容器,一個(gè)集群必須有一個(gè),即命令和控制集群中所有其他機(jī)器的系統(tǒng)。Docker容器改變了人們對(duì)開發(fā)、部署和維護(hù)軟件的思考方式,利用現(xiàn)代操作系統(tǒng)的本機(jī)隔離功能,容器支持類似于虛擬機(jī)的關(guān)注點(diǎn)分離,但是與基于虛擬機(jī)監(jiān)控程序的虛擬機(jī)相比,它的開銷要小得...

    yanest 評(píng)論0 收藏0
  • Kubernetes準(zhǔn)入控制器指南

    摘要:安全功能的最新引入是一組稱為準(zhǔn)入控制器的插件。通過將標(biāo)志傳遞給服務(wù)器來配置啟用的準(zhǔn)入控制器集。本討論將僅關(guān)注基于的準(zhǔn)入控制器。摘要準(zhǔn)入控制器為安全性提供了顯著優(yōu)勢。 作者:Malte Isberner(StackRox) Kubernetes極大地提高了當(dāng)今生產(chǎn)中后端群集的速度和可管理性。由于其靈活性、可擴(kuò)展性和易用性,Kubernetes已成為容器編排器的事實(shí)標(biāo)準(zhǔn)。Kubernete...

    solocoder 評(píng)論0 收藏0
  • Kubernetes準(zhǔn)入控制器指南

    摘要:安全功能的最新引入是一組稱為準(zhǔn)入控制器的插件。通過將標(biāo)志傳遞給服務(wù)器來配置啟用的準(zhǔn)入控制器集。本討論將僅關(guān)注基于的準(zhǔn)入控制器。摘要準(zhǔn)入控制器為安全性提供了顯著優(yōu)勢。 作者:Malte Isberner(StackRox) Kubernetes極大地提高了當(dāng)今生產(chǎn)中后端群集的速度和可管理性。由于其靈活性、可擴(kuò)展性和易用性,Kubernetes已成為容器編排器的事實(shí)標(biāo)準(zhǔn)。Kubernete...

    Loong_T 評(píng)論0 收藏0
  • Rancher 2.0快速上手指南

    摘要:而用戶能在同一平臺(tái)上管理任何集群,輕松地充分利用的強(qiáng)大能力及其迅速壯大的生態(tài)系統(tǒng)。在本指南中,你將會(huì)了解如何快速上手。環(huán)境中的所有主機(jī)必須允許彼此間的流量能夠進(jìn)行跨主機(jī)聯(lián)網(wǎng)。這一過程需要幾分鐘完成。如果服務(wù)正常,將會(huì)顯示狀態(tài)為綠色。 大家好,給大家介紹一下,這是幫助大家率先上手嘗試Rancher 2.0的神器 @Rancher 2.0快速上手指南 內(nèi)容導(dǎo)讀 準(zhǔn)備一臺(tái)Linux主機(jī) 啟...

    xiaodao 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<