org.apache.zookeeper.Zookeeper
Zookeeper 是在 Java 中客户端主类,负责建立与 zookeeper 集群的会话,并提供方法进行操作。
org.apache.zookeeper.Watcher
Watcher 接口表示一个标准的事件处理器,其定义了事件通知相关的逻辑,包含 KeeperState 和 EventType 两个枚举类,分别代表了通知状态和事件类型,同时定义了事件的回调方法:process(WatchedEvent event)。
process 方法是 Watcher 接口中的一个回调方法,当 ZooKeeper 向客户端发送一个 Watcher 事件通知时,客户端就会对相应的 process 方法进行回调,从而实现对事件的处理。
基本使用
maven的pom依赖
<dependency> <groupId>org.apache.zookeeper</groupId> <artifactId>zookeeper</artifactId> <version>3.4.9</version> </dependency>
java代码
1 public class ZKClient { 2 3 static ZooKeeper zk = null; 4 5 public static void main(String[] args) throws Exception { 6 7 //第一个参数:zk集群地址 host:port,多个地址之间用英文逗号分隔 8 //第二个参数:连接会话超时时间 单位为毫秒 9 //第三个参数:匿名new接口 监听 10 zk = new ZooKeeper("node-1:2181,node-2:2181,node-3:2181", 30000, new Watcher() { 11 //该方法为监听触发是回调的方法 12 public void process(WatchedEvent event) { 13 int i = 0; 14 System.out.println(++i); 15 System.out.println(event.getPath()); 16 System.out.println(event.getType()); 17 System.out.println(event.getState()); 18 //实现永久监听 19 try { 20 zk.getData("/itcastbyjava2", true, null); 21 } catch (KeeperException e) { 22 e.printStackTrace(); 23 } catch (InterruptedException e) { 24 e.printStackTrace(); 25 } 26 } 27 }); 28 // zk.create("/itcastbyjava2","123321".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT); 29 30 //设置监听 31 zk.getData("/itcastbyjava2", true, null); 32 33 zk.setData("/itcastbyjava2", "456".getBytes(), -1); 34 zk.setData("/itcastbyjava2", "789".getBytes(), -1); 35 36 zk.close(); 37 } 38 }
其他操作
1 public static void main(String[] args) throws Exception { 2 // 初始化 ZooKeeper 实例(zk 地址、会话超时时间,与系统默认一致、watcher) 3 ZooKeeper zk = new ZooKeeper("node-1:2181,node-2:2181,node-3:2181", 30000, new Watcher() { 4 @Override 5 public void process(WatchedEvent event) { 6 System.out.println("事件类型为:" + event.getType()); 7 System.out.println("事件发生的路径:" + event.getPath()); 8 System.out.println("通知状态为:" +event.getState()); 9 } 10 }); 11 // 创建一个目录节点 12 zk.create("/testRootPath", "testRootData".getBytes(), Ids.OPEN_ACL_UNSAFE, 13 CreateMode.PERSISTENT); 14 // 创建一个子目录节点 15 zk.create("/testRootPath/testChildPathOne", "testChildDataOne".getBytes(), 16 Ids.OPEN_ACL_UNSAFE,CreateMode.PERSISTENT); 17 System.out.println(new String(zk.getData("/testRootPath",false,null))); 18 // 取出子目录节点列表 19 System.out.println(zk.getChildren("/testRootPath",true)); 20 // 修改子目录节点数据 21 zk.setData("/testRootPath/testChildPathOne","modifyChildDataOne".getBytes(),-1); 22 System.out.println("目录节点状态:["+zk.exists("/testRootPath",true)+"]"); 23 // 创建另外一个子目录节点 24 zk.create("/testRootPath/testChildPathTwo", "testChildDataTwo".getBytes(), 25 Ids.OPEN_ACL_UNSAFE,CreateMode.PERSISTENT); 26 System.out.println(new String(zk.getData("/testRootPath/testChildPathTwo",true,null))); 27 // 删除子目录节点 28 zk.delete("/testRootPath/testChildPathTwo",-1); 29 zk.delete("/testRootPath/testChildPathOne",-1); 30 // 删除父目录节点 31 zk.delete("/testRootPath",-1); 32 zk.close(); 33 }