原来对子节点的新增、修改、删除的监听,以及当前节点的创建的监听方式如下:
@Test
public void testPathChildrenCache4Listener() throws Exception {
// 第一个参数,是监听的客户端
// 第二个参数,是监听的节点
// 第三个参数,是否缓存节点内容
PathChildrenCache pathChildrenCache = new PathChildrenCache(client, "/node1", true);
pathChildrenCache.start(PathChildrenCache.StartMode.POST_INITIALIZED_EVENT);
pathChildrenCache.getListenable().addListener(new PathChildrenCacheListener() {
public void childEvent(CuratorFramework curatorFramework, PathChildrenCacheEvent pathChildrenCacheEvent) throws Exception {
System.out.println(pathChildrenCacheEvent);
}
});
System.out.println("--------------1--------------");
client.create().forPath("/node1");
TimeUnit.MILLISECONDS.sleep(200);
System.out.println("--------------2--------------");
client.create().forPath("/node1/node1_1");
TimeUnit.MILLISECONDS.sleep(200);
System.out.println("--------------3--------------");
client.setData().forPath("/node1/node1_1", "new_data".getBytes());
TimeUnit.MILLISECONDS.sleep(200);
System.out.println("--------------4--------------");
client.delete().forPath("/node1/node1_1");
TimeUnit.MILLISECONDS.sleep(200);
System.out.println("--------------5--------------");
client.delete().forPath("/node1");
TimeUnit.MILLISECONDS.sleep(2000);
}
使用的 Listenable 如下:
public interface PathChildrenCacheListener {
public void childEvent(CuratorFramework client, PathChildrenCacheEvent event) throws Exception;
}
而现在推荐使用 CuratorCache
进行替代,但其对应的 Listenable 和之前不一样:
public interface CuratorCacheListener {
void event(Type type, ChildData oldData, ChildData data);
}
在新版本该如何使用新推荐或有其他方式对节点变化进行监听呢?
- deprecated list: http://curator.apache.org/api...