Curator学习

时间:2022-05-05 16:58:23

Curator是对zookeeper的高级封装。

考虑到使用它来开发zookeeper应用的方便,特此来记录总结学习与开发使用过程的问题。

1. curator-framework

Curator Framework提供了简化使用zookeeper更高级的API接口。它包涵很多优秀的特性,主要包括以下三点:

1)自动连接管理:自动处理zookeeper的连接和重试存在一些潜在的问题;可以watch NodeDataChanged event和获取             updateServerList;  Watches可以自动被Cruator recipes删除;

2)更干净的API:简化raw zookeeper方法,事件等;提供现代流式API接口

3)Recipe实现:leader选举,分布式锁,path缓存,和watcher,分布式队列等。

2.  Curator的重试策略

RetryPolicy接口只有一个方法(以前版本有两个方法) : 
public boolean allowRetry(int retryCount, long elapsedTimeMs); 
在开始重试之前, allowRetry方法被调用, 其参数将指定当前重试次数, 和操作已消耗时间. 如果允许, 将继续重试, 否则抛出异常.

Curator内部实现的几种重试策略:

1)ExponentialBackoffRetry:重试指定的次数, 且每一次重试之间停顿的时间逐渐增加.

2)RetryNTimes:指定最大重试次数的重试策略

3)RetryOneTime:仅重试一次

4)RetryUntilElapsed:一直重试直到达到规定的时间