client-go中的SharedInformerFactory机制

本文详细介绍了kubernetes client-go中的SharedInformerFactory,它作为工厂模式用于生成各种Informer。SharedInformerFactory允许共享相同资源类型的Informer以节省资源,但不同listOption需要不同factory。此外,通过PodInformer的例子展示了Informer的基本结构和功能,其核心为cache.SharedIndexInformer,负责资源的监听和更新。
摘要由CSDN通过智能技术生成

Table of Contents

1.章节介绍

本章首先介绍SharedInformerFactory,了解其组成和作用。

然后以Podinformer为例,了解一个资源实例的Informer应该需要实现哪些函数。

本节并没有设计到具体图中的informer机制,只是从大的入口入手,看看SharedInformerFactory到底是什么

 

2. SharedInformerFactory

SharedInformerFactory封装了NewSharedIndexInformer方法。字如其名,SharedInformerFactory使用的是工厂模式来生成各类的Informer。无论是k8s控制器,还是自定义控制器, SharedInformerFactory都是非常重要的一环。所以首先分析SharedInformerFactory。这里以一个实例入手分析SharedInformerFactory。

2.1 SharedInformerFactory实例介绍

package main
​
import (
    "fmt"
    clientset "k8s.io/client-go/kubernetes"
    "k8s.io/client-go/rest"
    "k8s.io/client-go/informers"
    "k8s.io/client-go/tools/cache"
    "k8s.io/api/core/v1"
    "k8s.io/apimachinery/pkg/labels"
    "time"
)
​
func main()  {
    config := &rest.Config{
        Host: "http://172.21.0.16:8080",
    }
    client := clientset.NewForConfigOrDie(config)
    // 生成SharedInformerFactory
    factory := informers.NewSharedInformerFactory(client, 5 * time.Second)
    // 生成PodInformer
    podInformer := factory.Core().V1().Pods()
    // 获得一个cache.SharedIndexInformer 单例模式
    sharedInformer := podInformer.Informer()
​
    //注册add, update, del处理事件
    sharedInformer.AddEventHandler(cache.ResourceEventHandlerFuncs{
        AddFunc:    func(obj interface{}) {fmt.Printf("add: %v\n&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值