kubernetes源码之watch包mux.go阅读理解二

本文详细探讨了kubernetes中watch包的mux.go文件,从总结、定义常量、广播器数据结构、创建及方法到广播器watcher的工作原理,全面解析了watch机制的关键实现。
摘要由CSDN通过智能技术生成

总结

此文件中主要有两个数据结构,一个广播器,一个是广播器wathcer
广播器实现的方法:
func (b *Broadcaster) blockQueue(f func())  
func (m *Broadcaster) Watch() Interface        向广播器中添加一个wathcer
func (m *Broadcaster) WatchWithPrefix(queuedEvents []Event) Interface  向广播器中添加一个有事件的wathcer
func (m *Broadcaster) stopWatching(id int64)     删除广播器中指定ID的watcher
func (m *Broadcaster) closeAll()    关闭所有watcher的result管道,并且清空广播器中的watcher
func (m *Broadcaster) loop()  将incoming的事件分发给watcher(具体分发由下一行实现)
func (m *Broadcaster) distribute(event Event)  具体分发给所有watcher的具体实现(对loop中分发的实现)
func (m *Broadcaster) Shutdown()
广播器wathcer只是具体对Interface的实现

定义常量

const incomingQueueLength = 25
type FullChannelBehavior int
const (
    WaitIfChannelFull FullChannelBehavior = iota
    DropIfChannelFull
)

广播器数据结构

type Broadcaster struct {
    // TODO: see if this lock is needed now that new watchers go
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值