问题:客户端如何获取Zookeeper服务器上最新数据?
方式一:客户端轮询指定节点下的数据,通过网络轮询,代价很大。
Zookeeper事件监听原理剖析_java
方式二:基于通知(notification)的机制:
客户端向ZooKeeper注册需要接收通知的znode,通过对znode设置监视点(watch)来接收通知。监视点是一个单次触发的操作,意即监视点会触发一个通知。
Zookeeper事件监听原理剖析_zookeeper_02
事件监听Watcher
Watcher 在 ZooKeeper 是一个核心功能,Watcher 可以监控目录节点的数据变化以及子节点的变化,一旦这些状态发生变化,服务器就会通知所有设置在这个目录节点上的Watcher,从而每个客户端都很快知道它所关注的目录节点的状态发生变化,而做出相应的反应。

JavaAPI:

  • 可以设置观察点的操作:exists,getChildren,getData
  • 可以触发观察的操作:create,delete,setData