curator zookeeper的高级封装库
是为了将zookeeper中的复杂操作隐藏起来,使得操作简单化,提供了操作的菜谱,并且结合了开发过程的最佳实践和常见的边际情况的处理;
curator实现了锁,屏障,缓存这些原语的菜谱,相关网址http://curator.apache.org/
curator中暴露和zookeeper不同的一组状态,如下为cutator中连接状态机模型
两种边界情况
1 在有序节点创建的过程中发生的错误情况的处理
2 删除一个节点时的错误处理
关于1的解释:
没有收到返回信息,在这种场景下,创建的时候会先添加一个唯一标示符,如果失败客户端就会重试,通过对比这个标示符,看节点是否创建成功
关于2的解释
如何对删除操作提供保障呢,会重试直到成功
三个菜谱
Leaderlatch LeaderSelector PathChildrenCache
1 节点选举
2群首选举
和leaderlatch之间的区别在于监听接口不同
3子节点缓存器,保存节点的列表和任务列表
还有很多菜谱提供开发者使用
来源:oschina
链接:https://my.oschina.net/u/1866807/blog/3014547