Zookeeper对节点的watch监听通知是永久的吗?为什么不是永久的?
不是。官方声明:一个Watch事件是一个一次性的触发器,当被设置了Watch的数据发生了改 变的时候,则服务器将这个改变发送给设置了Watch的客户端,以便通知它们。
为什么不是永久的,举个例子,如果服务端变动频繁,而监听的客户端很多情况下,每次变动 都要通知到所有的客户端,给网络和服务器造成很大压力。 一般是客户端执行getData(“/节点A”,true),如果节点A发生了变更或删除,客户端会得到它 的watch事件,但是在之后节点A又发生了变更,而客户端又没有设置watch事件,就不再给 客户端发送。
在实际应用中,很多情况下,我们的客户端不需要知道服务端的每一次变动,我只要最新的数 据即可。