[zk] CuratorFramework的LeaderLatch选主解析

本文深入解析了使用Zookeeper的CuratorFramework实现的LeaderLatch选主机制。主要内容包括分布式锁、顺序选主流程及监听方式。通过在ZK上创建临时有序节点,比较节点顺序来确定master节点,并在节点变化时通过watcher进行重新竞选。
摘要由CSDN通过智能技术生成

[zk] CuratorFramework的LeaderLatch选主解析

三个要点:分布式锁、顺序选主、监听方式

主要竞选流程

1、参与竞选的LeaderLatch实例在zookeeper上的{latchpath}目录创建临时有序子节点,如{latchpath}/latch-{seq},值默认为"".getBytes()。

2、创建有序节点成功后,回调函数,读取节点{latchpath}目录的所有子节点信息,对子节点的名称按{seq}从小到大排序,判断如果当前创建节点的值为最小的节点值,则断定当前的节点为master节点,回调执行isLeader的listener。否则当前节点未竞选master成功,成为一个follower,注册对前一个{seq}节点watcher事件,在watcher到NO_NODE事件后尝试重新竞选master。

1、LeaderLatch#start 启动竞选

public void start() throws Exception
    {
   
        //检测当前的LeaderLatch实例的状态为未开始选举
        Preconditions.checkState(state.compareAndSet(State.LATENT, State.STARTED), "Cannot be started more than once");

        //startTask为Feature对象,记录返回信息,AfterConnectionEstablished创建一个单线程池,提交任务(待zk的client连接建立后执行如下的 runnable 代码)
        startTask.set(AfterConnectionEstablished.execute(client, new Runnable()
        {
   
            @Override
            public void run()
            {
   
                try
                {
   
                    //执行具体的选举逻辑
                    internalStart();
                }
                finally
                {
   
                    startTask.set(null);
                }
            }
        }));
}

2、LeaderLatch#internalStart

    private synchronized void internalStart()
    {
   
        //二次确认当前转态是否为started
        if ( state.get() == State.STARTED )
        {
   
            //此时连接已经建立,这里添加一个zk的连接状态监听器,用于执行连接重连(重新参与竞选,reset)、阻塞(重置leader为false)、丢失(重置leader为false)等事件的逻辑
            client.getConnectionStateListenable().addListener(listener);
            try
            {
   
                //竞选相关的复用核心逻辑
                reset();
            }
            catch ( Exception e )
            
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值