-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathZKGetData.java
78 lines (66 loc) · 2.5 KB
/
ZKGetData.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
package demo;
import java.util.concurrent.CountDownLatch;
import org.apache.zookeeper.KeeperException;
import org.apache.zookeeper.WatchedEvent;
import org.apache.zookeeper.Watcher;
import org.apache.zookeeper.Watcher.Event.EventType;
import org.apache.zookeeper.ZooKeeper;
import org.apache.zookeeper.data.Stat;
/**
* https://www.tutorialspoint.com/zookeeper/zookeeper_api.htm
*/
public class ZKGetData {
private static ZooKeeper zk;
private static ZooKeeperConnection conn;
public static Stat znodeExists(String path) throws KeeperException, InterruptedException {
return zk.exists(path, true);
}
/**
* after running
* [zk: localhost:2181(CONNECTED) 2] set /MyFirstZnode HelloZookeeper
*
* console output :
* My first zookeeper app
* HelloZookeeper
*/
public static void main(String[] args) {
String path = "/MyFirstZnode";
final CountDownLatch connectedSignal = new CountDownLatch(1);
try {
conn = new ZooKeeperConnection();
zk = conn.connect("192.168.5.77");
Stat stat = znodeExists(path);
if (stat != null) {
byte[] b = zk.getData(path, new Watcher() {
@Override
public void process(WatchedEvent watchedEvent) {
if (watchedEvent.getType() == EventType.None) {
switch (watchedEvent.getState()) {
case Expired:
connectedSignal.countDown();
break;
}
} else {
String path = "/MyFirstZnode";
try {
byte[] bn = zk.getData(path, false, null);
String data = new String(bn, "UTF-8");
System.out.println(data);
connectedSignal.countDown();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}, null);
String data = new String(b, "UTF-8");
System.out.println(data);
connectedSignal.await();
} else {
System.out.println("Not exist node :: " + path);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}