1.创建Java工程:
右击 - New - Java Project
2.加入依赖包:
在Java Project下建立lib文件夹,拖入需要的jar包(包括/root/apps/zookeeper-3.4.5文件夹下的 zookeeper-3.4.5.jar 和 /lib下的.jar包)
选中lib下的所有jar包,右击 - BuildPath - add to build path
3.建立Java Class,开始编写zookeeper客户端:
找到src目录,右击 - New Class
java客户端用于对数据的增,删,改,查,监听,并做出适当的响应
代码:
public class SimplezkClient {
private static final String connectString="192.168.179.200:2181,192.168.179.201:2181,192.168.179.202:2181";
private static final int sessionTimeout = 2000;
ZooKeeper zkClient = null;
@before
public void init() throws Exception{
// 客户端api对象 参数依次为:连接字符串(zookeeper服务器的地址,可以加入多个服务器),会话超时,监听器
zkClient = new ZooKeeper(connectString,sessionTimeout,new Watcher() {
@Override
public void process(WatchedEvent event) {
// 收到事件通知后的回调函数(事件处理逻辑)
System.out.println(event.getType() + "---" + event.getPath());
try {
zkClient.getChildren("/", true); //再次绑定监听器,因为监听器只生效一次。这样做可以实现永久的监听
} catch (Exception e) {
}
}
});
}
// 数据的增删改查
// 创建数据节点到zk中
public void testCreate() throws KeeperException, InterruptedException{
// 创建节点,参数依次为:节点路径,节点保存的数据,节点的权限和节点类型,返回所创建节点的路径
String nodeCreated = zkClient.create("/eclipse", "hellozk".getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
//上传的数据可以是任何类型,但都要转成byte[]
}
// 获取子节点
@Test
public void getChildren() throws Exception {
List<String> children = zkClient.getChildren("/", true); # true: 绑定zkClient对象的监听器,监听"/"节点的子节点更新事件,监听器只通知(生效)一次
for (String child : children) {
System.out.println(child);
}
Thread.sleep(Long.MAX_VALUE); // 阻止程序退出
}
// 判断znode是否存在
@Test
public void testExist() throws Exception{
Stat stat = zkClient.exists("/eclipse", false); # 不绑定监听器(监听节点被删除事件),如果节点不存在,返回null;如果节点存在,返回该节点的元数据
System.out.println(stat==null?"not exist":"exist");
}
// 获取znode的数据
@Test
public void getData() throws Exception {
byte[] data = zkClient.getData("/eclipse", false, null); # 不绑定监听器(监听节点上数据改变事件) , 返回二进制类型的数据,null表示获取的是最新的版本
System.out.println(new String(data));
}
//删除znode
@Test
public void deleteZnode() throws Exception {
//参数2:指定要删除的版本,-1表示删除所有版本
zkClient.delete("/eclipse", -1);
}
//修改znode的数据
@Test
public void setData() throws Exception {
zkClient.setData("/app1", "imissyou angelababy".getBytes(), -1); # -1表示修改所有版本的数据
byte[] data = zkClient.getData("/app1", false, null);
System.out.println(new String(data));
}
}
客户端监听器工作原理:
listen线程和connect线程都是守护线程。
Java的线程分为两种类型:普通线程和守护线程。
当主线程执行完毕时,若有普通线程还在运行,则主线程不会退出;若其他在运行的线程都是守护线程,则主线程退出。