栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 其他

4.2.3、Zookeeper

其他 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

4.2.3、Zookeeper

1、导包maven上下载:3.4.6 2、连接:端口2181

参数:集群的每个主机名,会话时间(多长时间没有连上就不行),监视器

public class Demo01 {
    public static void main(String[] args) throws Exception {
        ZooKeeper zooKeeper = new ZooKeeper("master:2181,node1:2181,node2:2181", 3000, null);
        //创建一个节点,数据
        zooKeeper.create("/test", "test".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
        //获取数据
        Stat stat = new Stat();
        byte[] data = zooKeeper.getData("/test", true, stat);
        System.out.println(Arrays.toString(data));
    }
}
节点类型:

持久:断开连接,创建的节点不删除
短暂:断开连接,节点删除

类型描述
CreateMode.PERSISTENT永久性节点
CreateMode.PERSISTENT_SEQUENTIAL永久性序列节点
CreateMode.EPHEMERAL临时节点,会话断开或过期时会删除此节点
CreateMode.PERSISTENT_SEQUENTIAL临时序列节点,会话断开或过期时会删除此节点

操作:

public class Demo03 {
    ZooKeeper zooKeeper;
    @Before
    public void getinit()throws Exception{
        //连接,监听器
            zooKeeper = new ZooKeeper("master:2181,node1:2181,node2:2181", 2000, new Watcher() {
                public void process(WatchedEvent watchedEvent) {
                    List children = null;
                    try {
                        //获取路径监听
                        children = zooKeeper.getChildren("/", true);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                    //输出所有节点
                    for (String child : children) {
                        System.out.println(child);
                    }
                }
            });
    }
    
    //获取子节点
    @Test
    public void getChinld()throws Exception{
        List children = zooKeeper.getChildren("/", true);
        for (String child : children) {
            System.out.println(child);
        }
        Thread.sleep(Long.MAX_VALUE);
    }
    
    //判断节点是否存在
    @Test
    public void getExists()throws Exception{
        Stat exists = zooKeeper.exists("/d", false);
        System.out.println(exists==null?0:1);
    }
     //修改数据  ,-1表示忽略版本
    @Test
     public void getUpdata()throws Exception{
         Stat stat = zooKeeper.setData("/test", "123456789".getBytes(), -1);
         System.out.println(stat==null?0:1);
     }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/279429.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号