在Kubernetes client-go库中如何有效构建CRD的informer

简介: 构建并运行Informer之后,你的应用现在能够实时地响应Kubernetes中的CRD资源变化事件。这是一个强大的模式,它可以使得你的应用更加智能地与你的Kubernetes集群互动。通过上述步骤,你可以创建一个强大、可扩展且与Kubernetes紧密集成的系统。

在Kubernetes ecosystem中,client-go库是一个强大的集合,它提供了与Kubernetes API进行交互的工具,使得我们可以在自己的应用程序中进行创建、配置以及管理Kubernetes资源。而对于自定义资源的定义(CRD),client-go也提供了informer的机制,此机制能够帮助我们监听资源的变化事件(如创建、更新和删除事件)。

构建一个CRD的Informer涉及以下几个核心步骤:

  1. 通过CRD定义生成客户端集合:首先,基于CRD定义生成相应的客户端代码。你可能需要使用如k8s.io/code-generator这样的代码生成工具来生成相应的API客户端代码。
  2. 建立自定义的Informer工厂:然后你需要通过从client-go中导入的工厂模块来建立自定义的Informer工厂实例。这个实例会根据你的自定义资源类型创建一个新的Informer。
  3. 创建和配置Informer:通过Informer工厂实例来创建Informer,在这个步骤中你可以对Informer进行配置,比如设置同步时间间隔,它决定了Informer多久拉取一次资源的最新状态。
  4. 设置事件处理程序:一旦Informer被创建,你需要设置资源事件的处理程序(handlers),例如当资源被添加、更新或删除时,你可以注册自定义逻辑来反应这些事件。
  5. 运行Informer:最后,启动Informer。Informer将在后台运行,并且监听自定义资源的变化,一旦发生变化,它就会调用你为这些事件注册的处理程序。

下面将详细阐述这些步骤。

1. 通过CRD定义生成客户端集合

使用k8s.io/code-generator这样的工具可以自动根据你的CRD定义生成Go语言的客户端库。这样可以为你的自定义资源类型生成类型化的客户端代码,通过这些代码,你可以更为简单地操作Kubernetes中的自定义资源。

2. 建立自定义的Informer工厂

与client-go库中为核心Kubernetes资源提供的Informer相似,你可以为CRD实现自己的Informer工厂。这通常涉及到引用自动生成的客户端集合,并且创建一个新的Informer工厂实例。

例如:

import (
    "mycustomclientset "github.com/myorganization/myproject/pkg/client/clientset/versioned"
    "k8s.io/client-go/informers"
    "k8s.io/client-go/tools/cache"
)

// 使用自定义clientset创建Informer工厂
factory := informers.NewSharedInformerFactory(mycustomclientset, time.Minute*10)
​

3. 创建和配置Informer

通过Informer工厂,构建出你的CRD资源对应的Informer。

informer := factory.ForResource(myCustomResourceGVR).Informer()
​

4. 设置事件处理程序

设置用于处理不同事件的回调函数,如添加、更新、删除等。

informer.AddEventHandler(cache.ResourceEventHandlerFuncs{
    AddFunc: func(newObj interface{}) {
        // 处理新增资源的逻辑
    },
    UpdateFunc: func(oldObj, newObj interface{}) {
        // 处理更新资源的逻辑
    },
    DeleteFunc: func(obj interface{}) {
        // 处理删除资源的逻辑
    },
})
​

5. 运行Informer

最后,你需要启动Informer,这通常是在你的应用程序的主函数或某个goroutine中完成。

stopCh := make(chan struct{})
defer close(stopCh)

// 启动Informer
go informer.Run(stopCh)

// 等待Informer关闭
<-stopCh
​

构建并运行Informer之后,你的应用现在能够实时地响应Kubernetes中的CRD资源变化事件。这是一个强大的模式,它可以使得你的应用更加智能地与你的Kubernetes集群互动。通过上述步骤,你可以创建一个强大、可扩展且与Kubernetes紧密集成的系统。

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
2月前
|
Kubernetes API Go
利用k8s client-go库创建CRD的informer的操作流程
以上步骤将创建一个针对特定 CRD 的 informer,该 informer 会触发相应的事件处理程序以便您对事件进行响应。这是一个高级的方案,需要对 Go 编程语言和 Kubernetes 内部机制有深入的了解。在应用之前,强烈建议深入了解 Kubernetes client-go 库以及其工作原理。
94 9
|
2月前
|
存储 canal 缓存
Redis篇
本内容整理了Redis缓存常见问题及解决方案,涵盖缓存穿透、击穿、雪崩的原理与应对策略,布隆过滤器的使用,缓存与数据库双写一致性方案(如读写锁、Canal组件),Redis持久化机制(RDB与AOF对比),数据过期与淘汰策略,分布式锁实现(如Redisson),主从同步、集群方案及高并发高可用保障措施,深入解析Redis性能优化与实际应用技巧,适合用于面试准备或技术提升。
71 0
|
运维 Kubernetes NoSQL
使用 Kubernetes 进行 Leader 选举
k8s 简化了我们在集群上部署、运维应用的流程。在 k8s 上,我们可以很方便地部署一个分布式应用。以 Deployment 为例,应用就由多个 Pod 组成,基于 Pod 的伸缩能力,应用天然就具备应用的高可用性和可扩展性。但在分布式系统中,通常我们需要指定其中一个 Pod 为 leader,负责协调所有 Pod 或执行特定任务。
2147 0
|
Kubernetes API 调度
【k8s系列5】KubernetesClientException: too old resource version 原因分析
【k8s系列5】KubernetesClientException: too old resource version 原因分析
1791 0
|
Java Maven 开发者
maven项目中官方setting.xml文件
`settings.xml` 是 Maven 的配置文件,用于定义用户或全局级别的构建行为。它包含本地仓库路径、网络代理、服务器认证、仓库镜像及构建配置文件等设置,帮助开发者根据环境定制 Maven 行为,提升构建效率与灵活性。
428 0
|
6月前
|
机器学习/深度学习 人工智能 物联网
MiniMind:2小时训练出你的专属AI!开源轻量级语言模型,个人GPU轻松搞定
MiniMind 是一个开源的超小型语言模型项目,帮助开发者以极低成本从零开始训练自己的语言模型,最小版本仅需25.8M参数,适合在普通个人GPU上快速训练。
1074 10
MiniMind:2小时训练出你的专属AI!开源轻量级语言模型,个人GPU轻松搞定
|
11月前
|
安全 测试技术 API
一图看懂API测试9种方法
一图看懂API测试九种方法:冒烟测试验证基本功能,功能测试确保符合规格,集成测试检查组件协同工作,回归测试防止新变更引入问题,负载测试评估性能稳定性,压力测试挑战极限负载,安全测试发现并修复漏洞,用户界面测试确保UI与API协调,模糊测试提升异常数据处理鲁棒性。
|
传感器 人工智能 自动驾驶
无人驾驶出租车具有许多优势和对网约车行业产生的重大影响。
无人驾驶出租车具有许多优势和对网约车行业产生的重大影响。
|
监控 Python
`pytest-qt` 是一个用于在 Qt 应用程序中进行 GUI 测试的 pytest 插件。
`pytest-qt` 是一个用于在 Qt 应用程序中进行 GUI 测试的 pytest 插件。
|
分布式计算 Serverless 数据处理
EMR Serverless Spark 实践教程 | 通过 Apache Airflow 使用 Livy Operator 提交任务
Apache Airflow 是一个强大的工作流程自动化和调度工具,它允许开发者编排、计划和监控数据管道的执行。EMR Serverless Spark 为处理大规模数据处理任务提供了一个无服务器计算环境。本文为您介绍如何通过 Apache Airflow 的 Livy Operator 实现自动化地向 EMR Serverless Spark 提交任务,以实现任务调度和执行的自动化,帮助您更有效地管理数据处理任务。
400 0