栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Curator简介

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Curator简介

1.简介

      Curator 框架是一个高级 API,它极大地简化了 ZooKeeper 的使用。它添加了许多基于 ZooKeeper 构建的功能,并处理管理与 ZooKeeper 集群的连接和重试操作的复杂性。其中一些功能是:

  1.    自动连接管理:
  • 存在需要 ZooKeeper 客户端重新创建连接和/或重试操作的潜在错误情况。Curator 自动且透明地(大部分)处理这些情况。
  • 监视 NodeDataChanged 事件并根据需要调用 updateServerList()。
  1.    更清洁的 API:
  • 简化原始 ZooKeeper 方法、事件等。
  • 提供现代、流畅的界面
  1.    其他实现:
  • 领导选举
  • 共享锁
  • 路径缓存和观察者
  • 分布式队列
  • 分布式优先队列

2.分配 Curator 框架实例

       Curatorframeworks 是使用 CuratorframeworkFactory 分配的,它提供了工厂方法和用于创建实例的构建器。重要提示:Curatorframework 实例是完全线程安全的。您应该在应用程序中为每个 ZooKeeper 集群共享一个 Curatorframework。

        工厂方法 (newClient()) 提供了一种创建实例的简化方法。Builder 可以控制所有参数。拥有 Curatorframework 实例后,您必须调用 start() 方法。在您的应用程序结束时,您应该调用 close()。

2.1命名空间

       因为 ZooKeeper 集群是一个共享环境,所以遵守命名空间约定至关重要,这样使用给定集群的各种应用程序就不会使用冲突的 ZK 路径。

       Curatorframework 有一个“命名空间”的概念。您在创建 Curatorframework 实例时设置命名空间(通过 Builder)。然后,Curatorframework 会在调用其 API 之一时将命名空间添加到所有路径。

Curatorframework    client = CuratorframeworkFactory.builder().namespace("MyApp") ... build();
client.create().forPath("/test", data);
3.使用

3.1添加依赖

        
            org.apache.curator
            curator-recipes
            2.10.0
        
        
            org.apache.zookeeper
            zookeeper
            3.4.6
        

3.2创建对应的Bean对象:

import org.apache.curator.framework.Curatorframework;
import org.apache.curator.framework.CuratorframeworkFactory;
import org.apache.curator.retry.ExponentialBackoffRetry;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import javax.annotation.Resource;

@Configuration
public class CuratorConfig {

    
    @Bean(destroyMethod ="close")
    public Curatorframework curatorframework(@Value("${zk.server.address}") String zkServerAddress) {
        ExponentialBackoffRetry retryPolicy = new ExponentialBackoffRetry(2000, 3);
        Curatorframework curatorframework = CuratorframeworkFactory.builder().connectString(zkServerAddress).retryPolicy(retryPolicy).namespace("namespace").build();
        curatorframework.start();
        return curatorframework;
    }
}
4.领导选举的实现

可参考链接:LeaderLatch的使用与分析_Jay的博客-CSDN博客_leaderlatch

public void init() {
        leaderLatch = new LeaderLatch(curatorframework, zkNodeProperties.getServers(), SystemUtil.getLocalIP());
        leaderLatch.addListener(new LeaderLatchListener() {
            @Override
            public void isLeader() {
                //当成为主节点时所作的操作
            }

            @Override
            public void notLeader() {
                //当成为从节点时所作的操作
            }
        });
        leaderLatch.start();

    }
5.监听节点

参考文献

Curatorframework节点监听二 TreeCache_hit_ynsun的博客-CSDN博客

workerNodePath = TreeCache.newBuilder(curatorframework, zkNodeProperties.getTasks()).setCacheData(false).build();
workerNodePath.getListenable().addListener((client, event) -> {
   //节点状态变化时所作的处理
});
workerNodePath.start();

参考链接:

Apache Curator framework –

Zookeeper框架Curator使用 - 扎心了,老铁 - 博客园

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/274648.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号