watch是由read operation设置的一次性触发器,由一个特定operation来触发。为了在server端管理watch,ZK的server端实现了watch manager。一个WatchManager类的实例负责管理当前已被注册的watch列表,并负责触发它们。所有类型的server(包括standalone,leader,follower和observer)使用同样的方式处理watch。
DataTree类持有一个watch manager来维护所有类型的watch和一些附加的数据,当处理一个带有watch的read operation时,此类就会把这个watch加入manager的watch列表。类似的,当处理一个事务时,此类会查明是否需要触发相应的watch。如果发现有watch需要触发,此类就会调用manager的触发方法。添加一个watch和触发一个watch都会以一个read请求或者FinalRequestProcessor类的一个事务开始。
在server端触发了一个watch,会传播到client。此类使用server cnxn对象来处理(参见ServerCnxn类),此对象管理client和server的连接并实现了Watcher接口。Watch.process方法序列化了watch event,并通过网络发送出去。client接收到了序列化数据,转换成watch event对象,并传递到应用程序。watch只会保存在内存,不会持久化到硬盘。当client断开与server的连接时,它的所有watch会从内存中清除。因为client的库也会维护一份watch的数据,在重连之后watch数据会再次被同步到server端。
相关推荐
领导者选举也是 ZooKeeper 的一个重要应用场景之一,主要用于确定集群中的主节点。其流程大致如下: 1. **尝试获取锁**:客户端尝试获取 `/servers/leader` 节点。 2. **跟随**:如果其他客户端已经成功创建了该...
嵌入式系统开发_STM32微控制器_ESP8266WiFi模块_心率传感器_加速度计_OLED显示屏_蓝牙40_低功耗设计_实时操作系统_智能手表_多功能健康监测_运动数据记录_
驾校自动化_网页自动化爬虫技术_Python27多线程HTTP请求模拟_龙泉驾校2014版约车系统自动预约助手_通过模拟登录和循环请求实现自动约车功能_支持失败自动递增车号重试_
Linux系统编程_操作系统内核_系统调用_进程线程_信号处理_文件IO_进程间通信_多线程同步_网络编程_UNIX环境编程_中文翻译勘误_错误修正_代码示例优化_技术文档校对_开
wanjunshe_Python-Tensorflow_12888_1745868924470
scratch少儿编程逻辑思维游戏源码-铅笔画.zip
即时通讯应用开发_基于LeanCloud云服务与Android原生开发_集成QQ第三方登录与即时聊天功能的社交应用_实现用户注册登录创建聊天室发送文字消息展示用户信息头像昵称并提供
scratch少儿编程逻辑思维游戏源码-伞兵大乱斗(云变量).zip
scratch少儿编程逻辑思维游戏源码-楼层酷跑.zip
scratch少儿编程逻辑思维游戏源码-零下之寒颤.zip
scratch少儿编程逻辑思维游戏源码-密室逃生.zip
少儿编程scratch项目源代码文件案例素材-爪猫足球.zip
命令行完成git本地仓库创建、将代码提交到暂存区、查看暂存区信息、将代码提交到本地仓库、将本地仓库关联到远程仓库、推送到远程仓库全过程的截图
少儿编程scratch项目源代码文件案例素材-纸.zip
scratch少儿编程逻辑思维游戏源码-日本冒险.zip
scratch少儿编程逻辑思维游戏源码-狼人杀跑酷.zip
scratch少儿编程逻辑思维游戏源码-史莱姆杀手.zip
少儿编程scratch项目源代码文件案例素材-粘粘世界.zip
scratch少儿编程逻辑思维游戏源码-米克 demo.zip
网络游戏开发_Netty4X框架_多协议支持_高性能分布式游戏服务器_基于TCP_UDP_HTTP_WebSocket协议栈_Protobuf自定义通信协议_RPC远程调用_My