ZooKeeper【客户端的API操作、写数据流程】

本文涉及的产品
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,182元/月
简介: ZooKeeper【客户端的API操作、写数据流程】

前置工作

创建Maven工程

导入依赖

<dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.18.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.5.7</version>
        </dependency>
    </dependencies>

配置log4j

log4j.rootLogger=INFO, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c]- %m%n
log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=target/spring.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p [%c]- %m%n

API 操作实例

初始化方法

 @Before
    public void init() throws IOException {
        zkClient = new ZooKeeper(connectString, sessionTimeOut, new Watcher() {
            //process方法可以为空 在这里设置的监听并不是监听一次就关闭而是一直监听            
            @Override
            public void process(WatchedEvent watchedEvent) {
                System.out.println("----------init------------");
                List<String> children = null;
                try {
                    children = zkClient.getChildren("/sanguo", true);
                } catch (KeeperException | InterruptedException e) {
                    e.printStackTrace();
                }
                for (String child : children) {
                    System.out.println(child);
                }
            }
        });
    }

创建节点

create方法的参数:

  1. path:要创建的节点路径
  2. data:节点的数据
  3. acl:一个List<ACL>类型的权限集合
  4. createMode:创建的节点类型
@Test
    public void create() throws InterruptedException, KeeperException {
        //创建节点并返回节点路径/sanguo/wuguo
        String Znode = zkClient.create("/sanguo/wuguo", "liubei".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
        System.out.println("Znode : "+Znode);
    }

获取子节点并监听

       只要在init方法中新建了Watcher类并实现了process方法,就会一直监听而不是监听一次就自动关闭。

 @Test
    public void getChildren() throws InterruptedException, KeeperException {
        System.out.println("--------------------");
        /**设置watcher为true之后就会自动执行init方法中watcher的重写的process方法
        * 如果process方法为空,则这里只会监听一次就关闭监听
        **/
        List<String> children = zkClient.getChildren("/sanguo", true);
        /**这个for循环只会被执行一次 真正的监听在初始化ZooKeeper对象中重写Wather的process方法里
        *一旦监听的节点有变化,就会从process方法输出监听到的变化结果
        **/    
        for (String child : children) {
            System.out.println(child);
        }
        //延时程序 作用就是让客户端一直开启 以方便返回监听到的变化结果
        Thread.sleep(Long.MAX_VALUE);
    }

        我们发现,我们监听的是"/sanguo"但是当我们在它的孙目录"/sanguo/shuguo"下创建一个新节点时监听就不会生效,这是因为它只能监听子节点。

判断节点是否存在

@Test
    public void exits() throws InterruptedException, KeeperException {
        //返回节点状态 参数1是节点 参数2是是否开启监听
        Stat stat = zkClient.exists("/sanguo", false);
        System.out.println(stat==null?"not exist":"exit");
    }

写操作流程

       我们之前的操作都是在向zookeeper集群写数据,因为我们可以把zookeeper集群看做一个分布式小型文件系统,它存储着大量的Znode数据,只要一台服务器修改了Znode信息,我们集群中的每个节点都可以立即更新。

写数据流程通常只有两种情况:

  1. 直接发送写入请求给Leader
  2. 直接发送写入请求给Flower

1. 直接发送给Leader

  1. 客户端向Leader发送写数据请求
  2. 写入数据会首先写入领导者节点,领导者将数据同步到所有副本节点,当超过半数节点完成数据同步并回复成功消息后,写操作就算完成了,并通知客户端写入成功。(加入我们的zookeeper集群有三台节点,那么只要两台(Leader+任意一台Flower)同步完成就算写入成功)

3.之后剩余未同步的节点也会马上将数据同步,并告诉Leader自己同步完成。

2. 直接发送请求给Flower

  1. 客户端发送写入请求给Flower
  2. Flower没有写入的权限,于是将请求转发给Leader
  3. Leader收到请求,自己先写入一份,再将数据同步到所有副本节点,同样当超过半数的节点写入完成后,写操作就算完成了。
  4. 这时候Leader不会去告诉客户端写入完成,而是由向它转发请求的Flower原路返回给客户端。
  5. 同样之后剩余未同步的节点也会立即将客户端写入的数据同步,并告诉Leader自己已经同步完成。


相关文章
|
1月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
2月前
|
JSON API 数据安全/隐私保护
Python采集淘宝评论API接口及JSON数据返回全流程指南
Python采集淘宝评论API接口及JSON数据返回全流程指南
JSON 安全 API
80 0
JSON 监控 API
66 0
|
2月前
|
人工智能 API 开发者
图文教程:阿里云百炼API-KEY获取方法,亲测全流程
本文详细介绍了如何获取阿里云百炼API-KEY,包含完整流程与截图指引。需先开通百炼平台及大模型服务,再通过控制台创建并复制API-KEY。目前平台提供千万tokens免费额度,适合开发者快速上手使用。
1619 5
|
3月前
|
JSON 缓存 供应链
API 接口驱动 1688 采购自动化:从商品获取到下单支付的全流程贯通
在B2B电商采购中,1688开放平台通过API实现商品筛选、比价、下单、支付及物流跟踪的全流程自动化,大幅提升采购效率,降低人工成本与错误率。企业可无缝对接ERP系统,实现数据驱动决策,显著优化采购周期、成本与风险管控,助力数字化转型。
|
3月前
|
JSON 自然语言处理 供应链
API接口赋能1688采购全流程:从商品获取到下单支付一键贯通
1688采购API助力企业实现全流程自动化,涵盖商品数据获取、智能比价、一键下单、支付及物流跟踪等环节,显著提升采购效率,降低成本与风险,推动B2B采购模式智能化升级。
|
3月前
|
缓存 Java API
Spring WebFlux 2025 实操指南详解高性能非阻塞 API 开发全流程核心技巧
本指南基于Spring WebFlux 2025最新技术栈,详解如何构建高性能非阻塞API。涵盖环境搭建、响应式数据访问、注解与函数式两种API开发模式、响应式客户端使用、测试方法及性能优化技巧,助你掌握Spring WebFlux全流程开发核心实践。
607 0
|
4月前
|
存储 JSON 关系型数据库
【干货满满】解密 API 数据解析:从 JSON 到数据库存储的完整流程
本文详解电商API开发中JSON数据解析与数据库存储的全流程,涵盖数据提取、清洗、转换及优化策略,结合Python实战代码与主流数据库方案,助开发者构建高效、可靠的数据处理管道。
|
4月前
|
存储 监控 API
零基础 3 天搞定京东 / 淘宝 API 开发,从注册到调通接口全流程拆解
本文详解京东/淘宝API开发入门,涵盖账号注册、应用创建、签名生成及实战项目,助零基础开发者3天掌握电商API调用,实现商品数据获取与价格监控。

热门文章

最新文章