ZkClient之删除节点、更新节点、检测节点是否存在。

删除节点

在ZkClient中,可以通过以下API来删除指定节点:

  • boolean delete(final String path)
  • boolean delete(final String path, final AsyncCallback.VoidCallback callback, final Object context)
  • boolean deleteRecursive(String path)
该API方法的参数说明如下表所示。

参数名说明
path数据节点的完整节点路径
callback注册一个异步回调函数
context用于传递上下文信息的对象

通过调用这个接口,就可以对指定节点进行删除操作了。下面主要来看deleteRecursive接口。“在ZooKeeper中,只允许删除叶子节点。也就是说,如果一个节点存在至少一个子节点的话,那么该节点将无法被直接删除,必须先删除掉所有子节点”。但是在真正的生产使用中,我们的节点层级往往比较复杂,通常在4层左右。在这种情况下,如果每次都需要逐层遍历来删除节点,那么会非常繁琐。在ZkClient中,deleteRecursive这个接口将自动帮我们完成逐层遍历删除节点的工作,这为开发人员带来了不少便利。

更新节点

在ZkClient中,可以通过以下API来更新指定节点的数据:

  • void writeData(String path, Object data)
  • void writeData(final String path, Object data, final int expectedVersion)
该API方法的参数说明如下表所示。

参数名说明
path数据节点的完整节点路径
data数据内容,可以是null
expectedVersion预期的数据版本。可以使用这个数据版本来实现类似CAS的原子操作

通过调用这个接口,就可以对指定节点进行数据更新了。

检测节点是否存在

在ZkClient中,可以通过以下API来检测指定节点是否存在:

boolean exists(final String path)

通过调用这个接口,就可以检测指定节点是否存在了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值