Curator提供了三种Watcher:
(1)NodeCache:监听指定的节点。
(2)PathChildrenCache:监听指定节点的子节点。
(3)TreeCache:监听指定节点和子节点及其子孙节点。
// 根节点
private static final String rootPath = "/root";
// 子节点
private static final String dataPath = "/root/data";
// 孙子节点
private static final String nodePath = "/root/data/stock";
1、NodeCache:监听指定的节点
该节点监听的是/root/data/stock,库存操作的是/root/data/stock这个子节点,可以看到监听成功。
NodeCache nodeCache = new NodeCache(curatorFrameworkClient, nodePath);
nodeCache.getListenable().addListener(new MyNodeCacheListener());
nodeCache.start();
2、PathChildrenCache:监听指定节点的子节点
该节点监听的是/root/data,库存操作的是/root/data/stock这个子节点,可以看到监听成功。
PathChildrenCache pathChildrenCache = new PathChildrenCache(curatorFrameworkClient, dataPath,true);
pathChildrenCache.getListenable().addListener(new MyPathChildrenCacheListener());
pathChildrenCache.start(PathChildrenCache.StartMode.BUILD_INITIAL_CACHE);
3、TreeCache:监听指定节点和子节点及其子孙节点
监听的是root节点,库存操作的是/root/data/stock这个子节点,可以看到监听成功
TreeCache treeCache = new TreeCache(curatorFrameworkClient, rootPath);
treeCache.getListenable().addListener(new MyTreeCacheListener());
treeCache.start();
4、很遗憾上面的三种监听方式都过时了,取而代之的是CuratorCacheListener
该监听方式直接替换了上面的三种过时的监听方式。
CuratorCache curatorCache = CuratorCache.build(curatorFrameworkClient, dataPath);
CuratorCacheListener listener = CuratorCacheListener
// 1、监听指定的节点
// .builder().forNodeCache(new MyNodeCacheListener())
// 2、监听指定节点及其子节点的数据变化
.builder().forPathChildrenCache(dataPath, curatorFrameworkClient, new MyPathChildrenCacheListener())
// 3、监听指定节点及其子节点孙子节点的数据变化
// .builder().forTreeCache(curatorFrameworkClient, new MyTreeCacheListener())
.build();
curatorCache.listenable().addListener(listener);
curatorCache.start();