亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

自定義資源CRD使用介紹

 更新時間:2022年05月13日 17:17:44   作者:李大鵝  
這篇文章主要為大家介紹了自定義資源CRD的使用示例介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

介紹

Custom Resource Define簡稱 CRD,是 Kubernetes(v1.7+)為提高可擴展性,讓開發(fā)者去自定義資源的一種方式。

CRD 資源可以動態(tài)注冊到集群中,注冊完畢后,用戶可以通過 kubectl 來創(chuàng)建訪問這個自定義的資源對象,類似于操作 Pod 一樣。

不過需要注意的是 CRD 僅僅是資源的定義而已,需要一個對應的控制器去監(jiān)聽 CRD 的各種事件來添加自定義的業(yè)務邏輯。

定義

如果說只是對 CRD 資源本身進行 CRUD 操作的話,不需要 Controller 也是可以實現(xiàn)的,相當于就是只有數(shù)據(jù)存入了 etcd 中,而沒有對這個數(shù)據(jù)的相關操作而已。

比如我們可以定義一個如下所示的 CRD 資源清單文件:

apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
  # name 必須匹配下面的spec字段:<plural>.<group>  
  name: foos.crd.example.com
  # for more information on the below annotation, please see
  # https://github.com/kubernetes/enhancements/blob/master/keps/sig-api-machinery/2337-k8s.io-group-protection/README.md
  annotations:
    "api-approved.kubernetes.io": "unapproved, experimental-only; please get an approval from Kubernetes API reviewers if you're trying to develop a CRD in the *.k8s.io or *.kubernetes.io groups"
spec:
  # group 名用于 REST API 中的定義: /apis/<group>/<version>
  group: crd.example.com
  # 列出自定義資源的所有 API 版本
  versions:
    - name: v1  # 版本名稱,比如v1,v1beta1
      served: true  # 是否開啟通過 REST APIs訪問 `/apis/<group>/<version>/...`
      storage: true # 必須將一個且只有一個版本標記為存儲版本
      schema: # 定義自定義對象的聲明規(guī)范
        # schema used for validation
        openAPIV3Schema:
          type: object
          properties:
            spec:
              type: object
              properties:
                deploymentName:
                  type: string
                replicas:
                  type: integer
                  minimum: 1
                  maximum: 10
            status:
              type: object
              properties:
                availableReplicas:
                  type: integer
  names:
    # kind 是 sigular 的一個駝峰形式的定義,在資源清單中會使用
    kind: Foo
    # plural 名字用于 REST API 中的定義:/apis/<group>/<version>/<plural>    
    plural: foos
    # singular 名稱用于 CLI 操作或顯示的一個別名    
    singular: foo
    # shortNames 相當于縮寫形式    
    shortNames:
    - fo
  scope: Namespaced

這個地方的定義和我們定義普通的資源對象比較類似,我們可以隨意定義一個自定義的資源對象,但是在創(chuàng)建資源的時候,肯定不是任由我們隨意去編寫 YAML 文件的,當我們把上面的 CRD 文件提交給 Kubernetes 之后,Kubernetes 會對我們提交的聲明文件進行校驗,從定義可以看出 CRD 是基于OpenAPI v3 schem進行規(guī)范的。

當然這種校驗只是對于字段的類型進行校驗,比較初級,如果想要更加復雜的校驗,這個時候就需要通過 Kubernetes 的 admission webhook 來實現(xiàn)了。關于校驗的更多用法,可以前往官方文檔查看。

現(xiàn)在我們可以直接使用kubectl來創(chuàng)建這個CRD資源清單:

$  kubectl apply -f crd.example.com_foos.yaml 
customresourcedefinition.apiextensions.k8s.io/foos.crd.example.com created

這個時候我們可以查看到集群中已經(jīng)有我們定義的這個CRD資源對象了:

$ kubectl get crd | grep example
foos.crd.example.com                                  2022-05-11T05:28:51Z

這個時候一個新的 namespace 級別的 RESTful API 就會被創(chuàng)建:

/apis/crd/example.com/v1/namespaces/*/foos/...

接著我們就可以使用這個 API 端點來創(chuàng)建和管理自定義的對象,這些對象的類型就是上面創(chuàng)建的 CRD 對象規(guī)范中的foo

現(xiàn)在在 Kubernetes 集群中我們就多了一種新的資源叫做foos.crd.example.com,我們就可以使用它來定義一個Foo資源對象了,這個自定義資源對象里面可以包含的字段我們在定義的時候通過schema進行了規(guī)范,比如現(xiàn)在我們來創(chuàng)建一個如下所示的資源清單:

apiVersion: crd.example.com/v1
kind: Foo
metadata:
  name: example-foo
spec:
  deploymentName: example-foo
  replicas: 1

創(chuàng)建完成后我們就可以用kubectl來管理我們這里創(chuàng)建的Foo對象了,比如:

kubectl get foo
NAME          AGE
example-foo   20m

在使用 kubectl 的時候,資源名稱是不區(qū)分大小寫的,我們可以使用 CRD 中定義的單數(shù)或者復數(shù)形式以及任何簡寫。

kubectl get foo example-foo -o yaml
apiVersion: crd.example.com/v1
kind: Foo
metadata:
  annotations:
    kubectl.kubernetes.io/last-applied-configuration: |
      {"apiVersion":"crd.example.com/v1","kind":"Foo","metadata":{"annotations":{},"name":"example-foo","namespace":"default"},"spec":{"deploymentName":"example-foo","replicas":1}}
  creationTimestamp: "2022-05-11T05:40:38Z"
  generation: 1
  name: example-foo
  namespace: default
  resourceVersion: "37605212"
  uid: 56d5b1d3-f6f9-4106-90c4-a0e3c7d130c0
spec:
  deploymentName: example-foo
  replicas: 1

就如上面我們說的,現(xiàn)在我們自定義的資源創(chuàng)建完成了,但是也只是單純的把資源清單數(shù)據(jù)存入到了 etcd 中而已,并沒有什么其他用處,因為我們沒有定義一個對應的控制器來處理相關的業(yè)務邏輯。

以上就是自定義資源CRD使用介紹的詳細內(nèi)容,更多關于自定義資源CRD的資料請關注腳本之家其它相關文章!

相關文章

  • Spark實現(xiàn)K-Means算法代碼示例

    Spark實現(xiàn)K-Means算法代碼示例

    這篇文章主要介紹了Spark實現(xiàn)K-Means算法代碼示例,簡單介紹了K-Means算法及其原理,然后通過具體實例向大家展示了用spark實現(xiàn)K-Means算法,需要的朋友可以參考下。
    2017-10-10
  • Hadoop 2.x與3.x 22點比較,Hadoop 3.x比2.x的改進

    Hadoop 2.x與3.x 22點比較,Hadoop 3.x比2.x的改進

    本文介紹了Hadoop3版本中添加的新功能,Hadoop 2和Hadoop 3的區(qū)別,在這篇文章中,我們將討論Hadoop 2.x與Hadoop 3.x之間的比較。感興趣的朋友跟隨小編一起看一下
    2018-09-09
  • tkestack/gpu-manager在k8s1.23版本之后的使用方法

    tkestack/gpu-manager在k8s1.23版本之后的使用方法

    這篇文章主要介紹了tkestack/gpu-manager在k8s1.23版本之后的使用,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • k8s入門實戰(zhàn)deployment使用詳解

    k8s入門實戰(zhàn)deployment使用詳解

    這篇文章主要為大家介紹了k8s入門實戰(zhàn)deployment使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • Harbor高可用配置及倉庫使用介紹

    Harbor高可用配置及倉庫使用介紹

    這篇文章主要為大家介紹了Harbor高可用配置及倉庫使用介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • CentOS 7.9 升級內(nèi)核 kernel-ml-5.6.14版本的方法

    CentOS 7.9 升級內(nèi)核 kernel-ml-5.6.14版本的方法

    這篇文章主要介紹了CentOS 7.9 升級內(nèi)核 kernel-ml-5.6.14版本,默認內(nèi)核版本為3.10.0,現(xiàn)升級到 5.6.14 版本,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • kubernetes?Volume存儲卷configMap學習筆記

    kubernetes?Volume存儲卷configMap學習筆記

    這篇文章主要為大家介紹了kubernetes?Volume存儲卷configMap學習筆記,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • 云原生技術kubernetes之volumes容器的使用

    云原生技術kubernetes之volumes容器的使用

    這篇文章主要為大家介紹了云原生技術kubernetes之volumes容器使用方式,?有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-03-03
  • Kubernetes故障排除有效維護集群的最佳實踐工具

    Kubernetes故障排除有效維護集群的最佳實踐工具

    這篇文章主要為大家介紹了Kubernetes故障排除有效維護集群的最佳實踐工具詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • Prometheus?Operator架構介紹

    Prometheus?Operator架構介紹

    這篇文章主要為大家介紹了Prometheus?Operator架構介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11

最新評論