Watch事件监听
- ZooKeeper 允许用户在指定节点上注册一些Watcher,并且在一些特定事件触发的时候,ZooKeeper 服务端会将事件通知到感兴趣的客户端上去,该机制是 ZooKeeper 实现分布式协调服务的重要特性。
- ZooKeeper 中引入了Watcher机制来实现了发布/订阅功能能,能够让多个订阅者同时监听某一个对象,当一个对象自身状态变化时,会通知所有订阅者。
- Curator API中引入了 Cache 来实现对 ZooKeeper 服务端事件的监听。
- Zookeeper提供了三种Watcher
- NodeCache:监听指定的节点。
- PathChildrenCache:监听指定节点的子节点。
- TreeCache:监听指定节点及其子孙节点。
使用CuratorAPI获取zk服务器连接
private CuratorFramework client;
/**
* 获取连接
*/
@Before
public void getConnection() {
/*
String connectString:连接zookeeper服务器的参数字符串 ip:port
int sessionTimeoutMs:会话超时时间,在设置的时间内,客户端和服务器不交流,就断开连接
int connectionTimeoutMs:连接超时时间
RetryPolicy retryPolicy:重试策略;当客户端连接不上服务器的时候,使用什么样的重试策略。
策略如:1.一直继续连接,直到连接上位置
2.在尝试连接几次,连接不上就放弃连接。
....
RetryUntilElapsed: 是retryPolicy的实现类,表示一直重试,直到重试的时间超过最大时间后,就不再重试
maxElapsedTimeMs 最大重试时间
sleepMsBetweenRetries 每次重试的间隔时间
*/
client = CuratorFrameworkFactory.newClient("192.168.242.130:2181",
1000 * 60,
1000 * 10,
new RetryUntilElapsed(10 * 1000, 1000));
//开启连接
client.start();
}
NodeCache
监听指定节点
/**
* 监听指定的节点
*/
@Test
public void nodeCache() throws Exception {
//获取监听对象
NodeCache nodeCache = new