zookeeper入门到精通07——zookeeper客户端API节点操作与原理

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: zookeeper入门到精通07——zookeeper客户端API节点操作与原理

一、监听节点

先看看怎么获取子节点,启动zookeeper服务集群。编写并运行如下测试案例。

public class ZKClient {
    ZooKeeper client;
    @Before
    public void init() throws IOException {
        // 注意逗号后不要加空格,严格按照格式,在下面写自己对应得zookeeper服务集群得ip
        String connectString="192.168.106.43:2182,192.168.106.44:2182,192.168.106.45:2182";
//        String connectString="192.168.106.43,192.168.106.44,192.168.106.45";
        int sessionTimeout = 20000;
        client = new ZooKeeper(connectString, sessionTimeout, new Watcher() {
            @Override
            public void process(WatchedEvent watchedEvent) {
            }
        });
    }
    @Test
    public void grtChild() throws InterruptedException, KeeperException {
    // 参数true表示开启子节点的监听
        List<String> children = client.getChildren("/", true);
        for (String child: children) {
            System.out.println(child);
        }
    }
}

上面并不能实时监听节点的变化,即使我们在使用getChildren是开启了子节点的监听。这是因为两个原因:第一,程序执行完一次监听后就退出了。第二,监听器注册一次只能够监听一次(参考:Zookeeper入门到精通05——Zookeeper客户端命令行操作,小节:监听器原理)。如何才能够实时监听子节点,并且一有变化就输出呢?很简单,把上面的代码稍微修改下即可。

public class ZKClient {
    ZooKeeper client;
    @Before
    public void init() throws IOException {
        // 注意逗号后不要加空格,严格按照格式,在下面写自己对应得zookeeper服务集群得ip
        String connectString="192.168.106.43:2182,192.168.106.44:2182,192.168.106.45:2182";
//        String connectString="192.168.106.43,192.168.106.44,192.168.106.45";
        int sessionTimeout = 20000;
        client = new ZooKeeper(connectString, sessionTimeout, new Watcher() {
            @Override
            public void process(WatchedEvent watchedEvent) {
                List<String> children = null;
                try {
          // 参数true表示开启子节点的监听
                    children = client.getChildren("/", true);
                } catch (KeeperException e) {
                    e.printStackTrace();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                for (String child: children) {
                    System.out.println(child);
                }
            }
        });
    }
}
 @Test
    public void grtChild() throws InterruptedException, KeeperException {
        List<String> children = client.getChildren("/", true);
        for (String child: children) {
            System.out.println(child);
        }
        // 延时阻塞,防止程序退出
        Thread.sleep(Long.MAX_VALUE);
    }

二、判断节点是否存在

public class ZKClient {
    ZooKeeper client;
    @Before
    public void init() throws IOException {
        // 注意逗号后不要加空格,严格按照格式,在下面写自己对应得zookeeper服务集群得ip
        String connectString="192.168.106.43:2182,192.168.106.44:2182,192.168.106.45:2182";
//        String connectString="192.168.106.43,192.168.106.44,192.168.106.45";
        int sessionTimeout = 20000;
        client = new ZooKeeper(connectString, sessionTimeout, new Watcher() {
            @Override
            public void process(WatchedEvent watchedEvent) {}
        });
    }
   @Test
    public void exist() throws InterruptedException, KeeperException {
        Stat exists = client.exists("/sanguo1", false);
        System.out.println(exists==null?"not exist" : "exist");
    }
}

三、zookeeper的写数据原理

不管是采用命令行还是api操作zookeeper集群,其实都是对于zookeeper进行写数据操作,那它的底层原理是什么呢?

(1)直接向leader发写请求

3a6269229f434a47a579d422bb4ea702.png


如上图。假设zookeeper集群中有三台zookeeper服务器,首先client会给leader写数据,然后leader给其中一个follower写数据,之后follower会回复leaderr。此时,集群已经有半数服务器更新了数据,会由leader向client回复。之后leader继续与其它的follow进行数据同步与回复确认。

(2)向follower发写请求

cf349c837e57417e8c8547ca1c356bb7.png

如上图。client给follower发送写请求后,follower会将请求转发给leader,leader进行写操作,并且选择一台follower完成写操作,follower响应请求并回复。当超过半数的服务器完成写操作后,会由leader回复给最开始响应client的follower,并由它对client进行回复。之后继续完成其它follower的数据同步与应答。

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
相关文章
|
1月前
|
API
阿里云微服务引擎及 API 网关 2024 年 2 月产品动态
阿里云微服务引擎及 API 网关 2024 年 2 月产品动态
|
2月前
|
存储 缓存 Java
【Zookeeper】Apach Curator 框架源码分析:后台构造器和节点操作相关源码分析(二)【Ver 4.3.0】
【Zookeeper】Apach Curator 框架源码分析:后台构造器和节点操作相关源码分析(二)【Ver 4.3.0】
19 0
|
3天前
|
Java API Apache
ZooKeeper【基础 03】Java 客户端 Apache Curator 基础 API 使用举例(含源代码)
【4月更文挑战第11天】ZooKeeper【基础 03】Java 客户端 Apache Curator 基础 API 使用举例(含源代码)
21 11
|
4天前
|
存储 Java 网络安全
ZooKeeper【搭建 03】apache-zookeeper-3.6.0 伪集群版(一台服务器实现三个节点的ZooKeeper集群)
【4月更文挑战第10天】ZooKeeper【搭建 03】apache-zookeeper-3.6.0 伪集群版(一台服务器实现三个节点的ZooKeeper集群)
12 1
|
7天前
|
API
阿里云微服务引擎及 API 网关 2024 年 3 月产品动态
阿里云微服务引擎及 API 网关 2024 年 3 月产品动态。
|
11天前
|
存储
ZooKeeper客户端常用命令
ZooKeeper客户端常用命令
24 1
|
1月前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 API 网关 2024 年 02 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要。
|
1月前
|
消息中间件 存储 Kafka
Kafka【环境搭建 02】kafka_2.11-2.4.1 基于 zookeeper 搭建高可用伪集群(一台服务器实现三个节点的 Kafka 集群)
【2月更文挑战第19天】Kafka【环境搭建 02】kafka_2.11-2.4.1 基于 zookeeper 搭建高可用伪集群(一台服务器实现三个节点的 Kafka 集群)
140 1
|
2月前
|
NoSQL Java API
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
298 0
|
11天前
|
监控 负载均衡 Cloud Native
ZooKeeper分布式协调服务详解:面试经验与必备知识点解析
【4月更文挑战第9天】本文深入剖析ZooKeeper分布式协调服务原理,涵盖核心概念如Server、Client、ZNode、ACL、Watcher,以及ZAB协议在一致性、会话管理、Leader选举中的作用。讨论ZooKeeper数据模型、操作、会话管理、集群部署与管理、性能调优和监控。同时,文章探讨了ZooKeeper在分布式锁、队列、服务注册与发现等场景的应用,并在面试方面分析了与其它服务的区别、实战挑战及解决方案。附带Java客户端实现分布式锁的代码示例,助力提升面试表现。
29 2

热门文章

最新文章