zk中leader和follower启动时信息交互分析

发布时间:2021-11-15 10:56:47 作者:iii
来源:亿速云 阅读:116

本篇内容主要讲解“zk中leader和follower启动时信息交互分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“zk中leader和follower启动时信息交互分析”吧!

QuorumPeer中读取节点状态信息,不同状态下设置不同角色

zk中leader和follower启动时信息交互分析

1 Leader启动Follower接收器LearnerCnxAcceptor

LearnerCnxAcceptor负责接收非leader连接请求,线程中创建LearnerHandler处理器

2 Learner发起和leader的连接

Follower.followLeader()

Observer.observeLeader()

3 leader启动时会创建LearnerHandler

每个learnerHandler实例都对应一个leader和learner之间的连接,负责消息通信和

数据同步

4 向leader注册

learner和leader连接后。会向leader注册,即learner服务器基础信息

LearnerInfo zxid,sid发送给leader服务器

5 leader 接收到learner信息 服务器算出最新epoch

@Override
public long getEpochToPropose(long sid, long lastAcceptedEpoch) throws InterruptedException, IOException {
    synchronized (connectingFollowers) {
        if (!waitingForNewEpoch) {
            return epoch;
        }
        if (lastAcceptedEpoch >= epoch) {
            epoch = lastAcceptedEpoch + 1;
        }
        if (isParticipant(sid)) {
            connectingFollowers.add(sid);
        }
        QuorumVerifier verifier = self.getQuorumVerifier();
        if (connectingFollowers.contains(self.getId()) && verifier.containsQuorum(connectingFollowers)) {
            waitingForNewEpoch = false;
            self.setAcceptedEpoch(epoch);
            connectingFollowers.notifyAll();
        } else {
            long start = Time.currentElapsedTime();
            if (sid == self.getId()) {
                timeStartWaitForEpoch = start;
            }
            long cur = start;
            long end = start + self.getInitLimit() * self.getTickTime();
            while (waitingForNewEpoch && cur < end && !quitWaitForEpoch) {
                connectingFollowers.wait(end - cur);
                cur = Time.currentElapsedTime();
            }
            if (waitingForNewEpoch) {
                throw new InterruptedException("Timeout while waiting for epoch from quorum");
            }
        }
        return epoch;
    }
}

到此,相信大家对“zk中leader和follower启动时信息交互分析”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. zookeeper(7)源码分析-集群Leader选举FastLeaderElection
  2. SpringBoot打印启动时异常堆栈信息的示例分析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

zk observer epoch

上一篇:如何通过Exchange自带的EMS直接删除用户指定主题内容的邮件

下一篇:Kubernetes怎么安装集群

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》