首页 >后端开发 >Golang >何时使用 watch.Interface、cache.NewInformer、cache.NewSharedInformer 和 cache.NewSharedIndexInformer?

何时使用 watch.Interface、cache.NewInformer、cache.NewSharedInformer 和 cache.NewSharedIndexInformer?

Patricia Arquette
Patricia Arquette原创
2024-11-17 08:24:03386浏览

When to Use watch.Interface, cache.NewInformer, cache.NewSharedInformer, and cache.NewSharedIndexInformer?

watch.Interface vs.cache.NewInformer vs.cache.NewSharedIndexInformer:抽象级别指南

简介

在监控 Kubernetes 资源并对变化做出反应时,开发人员可以从 Kubernetes 中的各种选项中进行选择客户端程序包。本文旨在阐明 watch.Interface、cache.NewInformer、cache.NewSharedInformer 和 cache.NewSharedIndexInformer 之间的区别。

watch.Interface

watch.Interface 是一个低级抽象,允许您通过 ResultChan() 监视 Kubernetes 资源的更改。它提供添加/修改/删除事件,使您可以了解资源更改。但是,它仅包含资源的“之后”状态。

cache.NewInformer

cache.NewInformer 引入了更高级别的抽象。它包括观察器、列表器和内存缓存。通过实现cache.ResourceEventHandler,您可以接收OnAdd()/OnUpdate()/OnDelete()调用。这为您提供了资源的“之前”和“之后”状态,从而更方便地进行更改处理。

cache.NewSharedInformer

cache.NewSharedInformer在您的举报者之间共享与 API 服务器和其他资源的连接。这可以优化资源使用并提高性能。除非您对隔离有特定要求,否则建议使用 cache.NewInformer。

cache.NewSharedIndexInformer

cache.NewSharedIndexInformer 将索引添加到数据缓存。如果您正在处理大型数据集并且需要高效的索引以进行快速查找和过滤,这尤其有用。它是功能最丰富的选项,但实现起来也是最复杂的。

推荐

在大多数用例中,建议使用 SharedInformers 而不是较低的层次抽象。 SharedInformers 提供性能优势并简化资源管理。从同一个 SharedInformerFactory 实例化新的 SharedInformers 以实现最佳资源利用。

以上是何时使用 watch.Interface、cache.NewInformer、cache.NewSharedInformer 和 cache.NewSharedIndexInformer?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn