当前位置: 首页 > news >正文

奔驰宝马游戏网站建设网站建设自评报告

奔驰宝马游戏网站建设,网站建设自评报告,河西网站建设,北京常见网站建设推荐姚灿武#xff0c;Rancher 中国研发工程师#xff0c;拥有 7 年云计算领域经验#xff0c;热衷开源技术#xff0c;在云原生相关技术领域拥有丰富的开发和实践经验。 CRD#xff0c;即自定义资源定义#xff08;Custom Resource Definition#xff09;#xff0c;是 Ku… 姚灿武Rancher 中国研发工程师拥有 7 年云计算领域经验热衷开源技术在云原生相关技术领域拥有丰富的开发和实践经验。 CRD即自定义资源定义Custom Resource Definition是 Kubernetes API 中一个强大的扩展机制。通过 CRD用户可以定义自己的资源类型来扩展 Kubernetes 的 API 和资源类型。CRD 定义可以用于创建多个版本的资源这对于 Kubernetes 集群的演变和升级非常有用。 在本文中我们将介绍 Kubernetes CRD 的版本概念和使用方法讨论如何在 CRD 中定义多个版本的资源并讨论资源数据存储和数据转换的实现方式。最后我们将介绍如何开发 CRD webhook以便在 Kubernetes 中实现 CRD 版本兼容。 多版本 CRD 多版本 CRD 是指在 CRD 中定义多个版本的 API每个版本的 API 可以有自己的规则这样就可以在不影响旧版本应用程序的情况下对新版本应用程序进行更新和升级。 要创建多版本 CRD我们需要定义一个 Custom Resource Definition 对象该对象包含多个 version 字段。每个 version 字段都有一个 schema其中包含了自定义资源的属性和规则。 通过一个例子来说明以下是一个单版本 CRD 示例 apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata:name: foos.sample.webhook.io spec:conversion:strategy: Nonegroup: sample.webhook.ionames:kind: FoolistKind: FooListplural: foosshortNames:- foo- foossingular: fooscope: Namespacedversions:- name: v1schema:openAPIV3Schema:properties:apiVersion:type: stringkind:type: stringmetadata:type: objecttype: objectserved: truestorage: true文件中规定版本信息以及资源的名称、类型等信息。通过 kubectl apply 命令可以将该 CRD 文件应用到 Kubernetes 集群中从而在集群中创建一个新的资源类型 Foo例如 apiVersion: sample.webhook.io/v1 kind: Foo metadata:name: foo-sample上述自定义资源 Foo 只有一个 v1 版本如果我们需要更新自定义资源中的某个字段就需要更新 Foo 的版本例如更新为 v2 版本就要在 CRD 文件中添加 v2 版本的定义例如 apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata:name: foos.sample.webhook.io spec:versions:- name: v1schema:openAPIV3Schema:properties:apiVersion:type: stringkind:type: stringmetadata:type: objecttype: objectserved: truestorage: false- name: v2schema:openAPIV3Schema:properties:alias:type: stringapiVersion:type: stringkind:type: stringmetadata:type: objecttype: objectserved: truestorage: true在上述 CRD 文件中我们定义了两个版本v1 和 v2。v2 相比 v1 新增了一个 alias 字段。 资源数据存储 为确保 Kubernetes 能够正确地将自定义资源持久化到存储中并且能够正确地从存储中读取和还原自定义资源。CRD 中定义了 spec.versions.storage 字段用于指示使用哪个版本的 CRD 持久化到存储中。在一个 CRD 定义中只能有一个版本的 storage 字段的值为 true。 上述例子中我们定义了两个版本v1 和 v2。v1 版本 storage 字段为 falsev2 版本 storage 字段为 true这表明 Kubernetes etcd 中存储的是 v2 版本的资源数据。 那么对于未被选定的版本的数据如何存储呢以上面 foo-sample 为例我们来看下 etcd 中是怎么存储的结果如下 /registry/sample.webhook.io/foos/default/foo-sample {apiVersion:sample.webhook.io/v2,kind:Foo,metadata:{annotations:{kubectl.kubernetes.io/last-applied-configuration:{\apiVersion\:\sample.webhook.io/v1\,\kind\:\Foo\,\metadata\:{\annotations\:{},\name\:\foo-sample\,\namespace\:\default\}}\n},creationTimestamp:2023-05-22T09:49:03Z,generation:1,managedFields:[{apiVersion:sample.webhook.io/v1,fieldsType:FieldsV1,fieldsV1:{f:metadata:{f:annotations:{.:{},f:kubectl.kubernetes.io/last-applied-configuration:{}}}},manager:kubectl-client-side-apply,operation:Update,time:2023-05-22T09:49:03Z}],name:foo-sample,namespace:default,uid:3360f129-31f7-4a3f-8991-7694524d9a78}}第一行是 foo-sample 的 key第二行是 foo-sample json 格式表示的内容其中 apiVersion 为 sample.webhook.io/v2这表明即便 v1 版本的资源也以 v2 版本的格式存储。 数据转换 当自定义资源支持多个版本时因为只能以某一个版本的格式进行存储所以需要在存储的版本和提供的版本之间进行转换实现多版本兼容。 如果转换涉及模式变更 并且需要自定义逻辑则应该使用 Webhook 来完成。在 CRD 中配置 webhook 示例如下 apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition ... spec:  conversion:    strategy: Webhook    webhook:      clientConfig:        caBundle: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUJ2akNDQVdPZ0F3SUJBZ0lCQURBS0JnZ3Foa2pPUFFRREFqQkdNUnd3R2dZRFZRUUtFeE5rZVc1aGJXbGoKYkdsemRHVnVaWEl0YjNKbk1TWXdKQVlEVlFRRERCMWtlVzVoYldsamJHbHpkR1Z1WlhJdFkyRkFNVFk0TkRjegpPRGswTXpBZUZ3MHlNekExTWpJd056QXlNak5hRncwek16QTFNVGt3TnpBeU1qTmFNRVl4SERBYUJnTlZCQW9UCkUyUjVibUZ0YVdOc2FYTjBaVzVsY2kxdmNtY3hKakFrQmdOVkJBTU1IV1I1Ym1GdGFXTnNhWE4wWlc1bGNpMWoKWVVBeE5qZzBOek00T1RRek1Ga3dFd1lIS29aSXpqMENBUVlJS29aSXpqMERBUWNEUWdBRUZYWDQzaEZRdjRyOApKelR1UkJ0b3lqUmRtWjhIRkExbWZnOXJnTWVlNnVXZ20wMXBNR3lSRnFna3Z1RHF5RUlMTUtCRDduQ2IrVFp3CitBR3loVWhTV0tOQ01FQXdEZ1lEVlIwUEFRSC9CQVFEQWdLa01BOEdBMVVkRXdFQi93UUZNQU1CQWY4d0hRWUQKVlIwT0JCWUVGRzg2VnpCcW1wRUcrUWlrS0d1SGNIQlJwS2R3TUFvR0NDcUdTTTQ5QkFNQ0Ewa0FNRVlDSVFDaQp5SFFyeGNXN3dUM0dwRWhyNklQQWpXWDVJOSt4Y0dkUGQzQURKS0hwZ2dJaEFJQmhTc00xd1hxMU80VUlaWWZwCkNWVkxwaCtvUVMvMzI5OHMwS0VqWW9FTAotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg        service:          name: webhook-sample          namespace: default          path: /v1/webhook/conversion          port: 443      conversionReviewVersions:      - v1如果没有模式变更则可使用默认的 None 转换策略为不同版本提供服务时只有 apiVersion 字段会被改变。 apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition ... spec:...conversion:strategy: NoneCRD webhook 开发 与 Admission Webhook一样CRD webhook 也是一个 HTTP 回调webhook service 就是一个 HTTP 服务。接口结构如下 // ConversionReview describes a conversion request/response. type ConversionReview struct {metav1.TypeMeta json:,inline// request describes the attributes for the conversion request.// optionalRequest *ConversionRequest json:request,omitempty protobuf:bytes,1,opt,namerequest// response describes the attributes for the conversion response.// optionalResponse *ConversionResponse json:response,omitempty protobuf:bytes,2,opt,nameresponse }Harvester 项目组在 harvester webhook框架中增加了 CRD webhook 的支持开发者只需要实现 Converter 接口并把它注册到 webhook server 中然后启动 webhook server 即可。 // Converter is a interface to convert object to the desired version type Converter interface {GroupResource() schema.GroupResourceConvert(Object *unstructured.Unstructured, desiredAPIVersion string) (*unstructured.Unstructured, error) }具体开发细节请参考示例 webhook sample。 总 结 在实际产品进化演变过程中多版本兼容一直是一个重要的问题。Kubernetes CRD 采用选定某一个版本进行持久化并使用 webhook 实现多版本数据转换的策略来解决多版本兼容性问题。在 Kubernetes 外的其他项目中这种策略也值得学习借鉴。 参 考 Versions in Custom Resource Definitionshttps://kubernetes.io/zh-cn/docs/tasks/extend-kubernetes/custom-resources/custom-resource-definition-versioning
http://www.dnsts.com.cn/news/71533.html

相关文章:

  • 宿迁网站建设哪家最好wordpress 免费空间
  • 上海信息公司做网站为加强政协网站建设
  • 只做黑白摄影的网站济宁做网站大约多少钱
  • 织梦网站字体资阳做网站
  • 目前提供目录类搜索引擎的网站网站开发工程师年度总结
  • 重庆网站品牌推广wordpress 说说
  • 最好的餐饮设计网站建设做宣传用什么网站好
  • 网站怎么做查询功能网站网站平台建设方案
  • 佛山网站建设方案策划wordpress 注释模版
  • 网络营销前景和现状分析深圳网站的优化公司哪家好
  • 定陶区城乡建设局网站网站空间购买多少钱
  • win2012 iis 新建网站即将发布的新品手机
  • 网站改版用新空间好吗我的网站百度怎么搜索不到
  • 美食网网站建设目的免费自助建站排名
  • 泰安网站建设推广优化苍南龙港做网站店铺
  • 专门做衬衣的网站章丘环保网站建设 中企动力
  • 网站建设商务代表故事软件编程自学网
  • 做网站工资高不高个人主页搭建
  • 整站seo优化公司群晖wordpress慢
  • 湖南网站建设公司速来磐石网络郑州网站制作哪家好
  • 网站开发创新点贵阳两学一做网站
  • 织梦游戏网站源码西安做网站公司xamokj
  • 国内app公司排名seo信息查询
  • 上海招标网站四川新冠感染最新消息
  • wordpress静态页面seo要点
  • 上海做网站开发的公司有哪些wordpress 科技 主题
  • 做网站毕业答辩问题1920的网站做字体大小
  • phpcms 生成网站地图成都网站建设选择到访率
  • 做视频赚钱的网站做SEO公司多给网站
  • 网站标签图标代码成都高标建设有限公司官方网站