Zookeeper的API应用之非空节点的删除

本文详细介绍了如何使用Zookeeper API在Java中实现非空节点的递归删除,通过测试类和核心代码展示具体步骤,强调了在判断子节点集合时避免无限递归的重要性,同时讨论了保留根节点的条件。最后,展示了测试结果,成功从Zookeeper中删除了指定的非空节点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Zookeeper的API应用之非空节点的删除

除了在linux中用命令行方式(deleteall  非空目录)删除,也可以在idea中代码实现非空节点的删除
	//创建测试类
public class TestZKClient {
	//声明ZooKeeper,方便调用
    private ZooKeeper zk;
	//测试方法
    @Test
    public void delAllNode() throws KeeperException, InterruptedException {
        testDelNodes("/sanguo",zk);
    }
    /**
     * (核心代码)递归删除非空节点方法
     */
    public void testDelNodes(String path,ZooKeeper zk) throws KeeperException, InterruptedException {

        Stat stat = zk.exists(path, false);
		//判断传入的节点状态,非空进入
        if (stat != null) {
            System.out.println(path+" 存在");
            //先获取子节点
            List<String> chilNode = zk.getChildren(path, false);

            //递归删除节点,获取到的子节点集合非空进入
            if(chilNode!=null&&chilNode.size()>0){ //此判断内部如果不写删除语句,可以保留顶级父节点
            
                for (String nodeVal : chilNode) {

                    //递归子节点
                    testDelNodes(path+"/"+nodeVal,zk);
                }
                //删除本节点,这里不写能够保留根节点
                zk.delete(path,stat.getVersion());
            }else {
                //删除空节点
                zk.delete(path,stat.getVersion());
                
            }
        }else {
            System.out.println(path+" 不存在");
        }
    }

连接Zookeeper客户端
在这里插入图片描述

连接成功
在这里插入图片描述

/sanguo 目录下有三个子节点
在这里插入图片描述

执行测试delAllNode()方法程序
在这里插入图片描述

测试结果
在这里插入图片描述

Zookeeper中已经删除了/sanguo的非空节点
在这里插入图片描述
值得一提,如果想要保留根节点可将这句删除
在这里插入图片描述
还需要注意对节点集合的判断条件,如果不小心设为chilNode!=null,判断条件就是永真,因为即使当前节点没有子节点,getChildren返回的集合chilNode里面没有值,chilNode.size()=0但是chilNode不为空,所以永真,此时就永远不会执行else,遍历到一个空节点就删除,最终删除所有节点(保留不下根节点)

 //先获取子节点
  List<String> chilNode = zk.getChildren(path, false);
 //递归删除节点,获取到的子节点集合非空进入
  if(chilNode!=null)

本文内容知识点如果存在什么问题,欢迎各路大佬指正。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值