Curator实现Watch事件监听

本文介绍了ZooKeeper的Watcher事件监听机制,通过Curator API详细讲解了NodeCache、PathChildrenCache和TreeCache的用法,用于监听Zookeeper中节点及子节点的变化,强调了在添加监听前需建立与Zookeeper服务器的连接。
摘要由CSDN通过智能技术生成

Watch事件监听

  • ZooKeeper 允许用户在指定节点上注册一些Watcher,并且在一些特定事件触发的时候,ZooKeeper 服务端会将事件通知到感兴趣的客户端上去,该机制是 ZooKeeper 实现分布式协调服务的重要特性。
  • ZooKeeper 中引入了Watcher机制来实现了发布/订阅功能能,能够让多个订阅者同时监听某一个对象,当一个对象自身状态变化时,会通知所有订阅者。
  • Curator API中引入了 Cache 来实现对 ZooKeeper 服务端事件的监听。
  • Zookeeper提供了三种Watcher
    1. NodeCache:监听指定的节点。
    2. PathChildrenCache:监听指定节点的子节点。
    3. 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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值