package com.ruoyi;
import com.alibaba.fastjson.JSON;
import com.ruoyi.zookeeper.CliWatcher;
import org.apache.zookeeper.*;
import org.apache.zookeeper.data.Stat;
import java.io.IOException;
import java.util.List;
/**
* https://edu.51cto.com/center/course/lesson/index?id=339909
* 代码参考文档
* https://blog.csdn.net/u010391342/article/details/100404588
*/
public class Zoolkooprt {
public static void main(String[] args) throws IOException, KeeperException, InterruptedException {
//获取Zoolkooprt的链接,以及创建Zoolkooprt客户端
String connectString = "127.0.0.1:2181";
int sessionTimeOut = 3000;//超时的时间
Watcher watcher = new CliWatcher();
ZooKeeper zooKeeper = new ZooKeeper(connectString,sessionTimeOut,watcher);
Thread.sleep(2000);
System.out.println(zooKeeper.getState());
/**
* 操作ZooKeeper
* 命令创建新的目录 create /hello hello
*/
//List<String> stringList = zooKeeper.getChildren("/",true); //第二个参数是否监视该节点
//System.out.println(JSON.toJSONString(stringList));
//创建节点 OPEN_ACL_UNSAFE 表示 acl 权限列表完全开发 PERSISTENT表示节点类型为持久化节点
zooKeeper.create("/word","世界".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
//获取节点的数据(节点的值和节点的状态)
byte[] data = zooKeeper.getData("/word",true,null);
System.out.println(new String(data));
//修改
Stat stat = new Stat();
//获取数据
zooKeeper.getData("/hello",true,stat);
//版本可以设置成 -1 , -1 代表不检测版本
zooKeeper.setData("/hello","aaa".getBytes(),stat.getVersion());
//删除版本
zooKeeper.delete("/hello",-1);
}
}
java中访问zookeeper
最新推荐文章于 2022-03-12 12:03:41 发布