简介
在监控 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中文网其他相关文章!