iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何用Nacos实现Raft算法
  • 522
分享到

如何用Nacos实现Raft算法

2023-06-02 05:06:20 522人浏览 安东尼
摘要

这篇文章主要介绍“如何用Nacos实现Raft算法”,在日常操作中,相信很多人在如何用Nacos实现Raft算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何用Nacos实现Raft算法”的疑惑有所帮助!

这篇文章主要介绍“如何用Nacos实现Raft算法”,在日常操作中,相信很多人在如何用Nacos实现Raft算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何用Nacos实现Raft算法”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

导读为了提高理解性,Raft 将一致性算法分为了几个部分,包括领导选取(leader selection)、日志复制(log replication)、安全(safety),并且使用了更强的一致性来减少了必须需要考虑的状态。

快速了解Raft算法

Raft 适用于一个管理日志一致性的协议,相比于 Paxos 协议 Raft 更易于理解和去实现它。为了提高理解性,Raft 将一致性算法分为了几个部分,包括领导选取(leader selection)、日志复制(log replication)、安全(safety),并且使用了更强的一致性来减少了必须需要考虑的状态。

相比Paxos,Raft算法理解起来更加直观。

Raft算法将Server划分为3种状态,或者也可以称作角色:

Leader:负责Client交互和log复制,同一时刻系统中最多存在1个。

Follower:被动响应请求rpc,从不主动发起请求RPC。

Candidate:一种临时的角色,只存在于leader的选举阶段,某个节点想要变成leader,那么就发起投票请求,同时自己变成candidate。如果选举成功,则变为candidate,否则退回为follower

状态或者说角色的流转如下:

如何用Nacos实现Raft算法

在Raft中,问题分解为:领导选取、日志复制、安全和成员变化。

复制状态机通过复制日志来实现:

日志:每台机器保存一份日志,日志来自于客户端的请求,包含一系列的命令

状态机:状态机会按顺序执行这些命令

一致性模型:分布式环境下,保证多机的日志是一致的,这样回放到状态机中的状态是一致的

Raft算法选主流程

Raft中有Term的概念,Term类比中国历史上的朝代更替,Raft 算法将时间划分成为任意不同长度的任期(term)。

如何用Nacos实现Raft算法

选举流程

follower增加当前的term,转变为candidate。

candidate投票给自己,并发送RequestVote RPC给集群中的其他服务器

收到RequestVote的服务器,在同一term中只会按照先到先得投票给至多一个candidate。且只会投票给log至少和自身一样新的candidate。

Nacos中的CP一致性

spring cloud Alibaba Nacos 在 1.0.0 正式支持 AP 和 CP 两种一致性协议,其中的CP一致性协议实现,是基于简化的 Raft 的 CP 一致性。

如何实现Raft算法

Nacos server在启动时,会通过RunninGConfig.onApplicationEvent()方法调用RaftCore.init()方法。

启动选举

public static void init() throws Exception {       Loggers.RAFT.info("initializing Raft sub-system");       // 启动Notifier,轮询Datums,通知RaftListener     executor.submit(notifier);           // 获取Raft集群节点,更新到PeerSet中     peers.add(NamingProxy.getServers());       long start = System.currentTimeMillis();       // 从磁盘加载Datum和term数据进行数据恢复     RaftStore.load();       Loggers.RAFT.info("cache loaded, peer count: {}, datum count: {}, current term: {}",         peers.size(), datums.size(), peers.getTerm());       while (true) {         if (notifier.tasks.size() <= 0) {             break;         }         Thread.sleep(1000L);         System.out.println(notifier.tasks.size());     }       Loggers.RAFT.info("finish to load data from disk, cost: {} ms.", (System.currentTimeMillis() - start));       GlobalExecutor.reGISter(new MasterElection()); // Leader选举     GlobalExecutor.register1(new HeartBeat()); // Raft心跳     GlobalExecutor.register(new AddressServerUpdater(), GlobalExecutor.ADDRESS_SERVER_UPDATE_INTERVAL_MS);       if (peers.size() > 0) {         if (lock.tryLock(INIT_LOCK_TIME_SECONDS, TimeUnit.SECONDS)) {             initialized = true;             lock.unlock();         }     } else {         throw new Exception("peers is empty.");     }       Loggers.RAFT.info("timer started: leader timeout ms: {}, heart-beat timeout ms: {}",         GlobalExecutor.LEADER_TIMEOUT_MS, GlobalExecutor.HEARTBEAT_INTERVAL_MS); }

在init方法主要做了如下几件事:

获取Raft集群节点 peers.add(NamingProxy.getServers());Raft集群数据恢复 RaftStore.load();Raft选举 GlobalExecutor.register(new MasterElection());Raft心跳 GlobalExecutor.register(new HeartBeat());Raft发布内容Raft保证内容一致性

选举流程

其中,raft集群内部节点间是通过暴露的Restful接口,代码在 RaftController 中。RaftController控制器是raft集群内部节点间通信使用的,具体的信息如下:

POST Http://{ip:port}/v1/ns/raft/vote : 进行投票请求  POST HTTP://{ip:port}/v1/ns/raft/beat : Leader向Follower发送心跳信息  GET HTTP://{ip:port}/v1/ns/raft/peer : 获取该节点的RaftPeer信息  PUT HTTP://{ip:port}/v1/ns/raft/datum/reload : 重新加载某日志信息  POST HTTP://{ip:port}/v1/ns/raft/datum : Leader接收传来的数据并存入  DELETE HTTP://{ip:port}/v1/ns/raft/datum : Leader接收传来的数据删除操作  GET HTTP://{ip:port}/v1/ns/raft/datum : 获取该节点存储的数据信息  GET HTTP://{ip:port}/v1/ns/raft/state : 获取该节点的状态信息{UP or DOWN}  POST HTTP://{ip:port}/v1/ns/raft/datum/commit : Follower节点接收Leader传来得到数据存入操作  DELETE HTTP://{ip:port}/v1/ns/raft/datum : Follower节点接收Leader传来的数据删除操作  GET HTTP://{ip:port}/v1/ns/raft/leader : 获取当前集群的Leader节点信息  GET HTTP://{ip:port}/v1/ns/raft/listeners : 获取当前Raft集群的所有事件监听者 RaftPeerSet

心跳机制

Raft中使用心跳机制来触发leader选举。心跳定时任务是在GlobalExecutor 中,通过 GlobalExecutor.register(new HeartBeat())注册心跳定时任务,具体操作包括:

重置Leader节点的heart timeout、election timeout;

sendBeat()发送心跳包 public class HeartBeat implements Runnable {         @Override         public void run() {             try {                  if (!peers.isReady()) {                     return;                 }                  RaftPeer local = peers.local();                 local.heartbeatDueMs -= GlobalExecutor.TICK_PERIOD_MS;                 if (local.heartbeatDueMs > 0) {                     return;                 }                  local.resetHeartbeatDue();                  sendBeat();             } catch (Exception e) {                 Loggers.RAFT.warn("[RAFT] error while sending beat {}", e);             }          } }

简单说明了下Nacos中的Raft一致性实现,更详细的流程,可以下载源码,查看 RaftCore 进行了解。源码可以通过以下地址检出:

git clone https://GitHub.com/alibaba/nacos.git

如何用Nacos实现Raft算法

到此,关于“如何用Nacos实现Raft算法”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 如何用Nacos实现Raft算法

本文链接: https://www.lsjlt.com/news/229116.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何用Nacos实现Raft算法
    这篇文章主要介绍“如何用Nacos实现Raft算法”,在日常操作中,相信很多人在如何用Nacos实现Raft算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何用Nacos实现Raft算法”的疑惑有所帮助!...
    99+
    2023-06-02
  • 如何实现分布式共识算法Raft
    本篇内容主要讲解“如何实现分布式共识算法Raft”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现分布式共识算法Raft”吧!关于CAP原理C(一致性)A(...
    99+
    2024-04-02
  • 如何使用Raft组件
    这篇文章主要讲解了“如何使用Raft组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用Raft组件”吧!一、编译github下载 Ratis 直接 ...
    99+
    2024-04-02
  • nacos负载均衡如何实现
    Nacos提供了两种方式来实现负载均衡:客户端负载均衡和服务端负载均衡。1. 客户端负载均衡:在客户端进行负载均衡,客户端会通过Na...
    99+
    2023-09-04
    nacos
  • Raft 中怎么利用共识算法选举领导者
    今天就跟大家聊聊有关Raft 中怎么利用共识算法选举领导者,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Raft 是一种强领导者模型,即一切以领导者...
    99+
    2024-04-02
  • 如何使用Golang实现TOTP算法
    TOTP是一种基于时间的一次性密码,是为了增强安全性而提出的一种认证方式。它利用了服务器和客户端的时钟来生成短期的、一次性的密码,从而避免了在网络传输过程中密码被截获的风险。通过TOTP算法,客户端和服务器均可计算出同一令牌值,因此有效地保...
    99+
    2023-05-14
  • 如何利用python实现Simhash算法
    目录1. 为什么需要Simhash2. 文章关键词特征提取算法TD-IDF3. Simhash原理4. Simhash的不足5. Simhash算法实现1. 为什么需要Simhash...
    99+
    2024-04-02
  • 如何用PHP实现递归算法
    要使用PHP实现递归算法,首先需要定义一个递归函数。递归函数是指在函数内部调用函数本身的一种方法。下面是一个使用PHP实现递归算法的...
    99+
    2023-08-24
    PHP
  • 如何实现Consistent Hashing算法
    这篇文章给大家分享的是有关如何实现Consistent Hashing算法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在做服务器负载均衡时候可供选择的负载均衡的算法有很多,包括: 轮循算法(Round Robi...
    99+
    2023-06-17
  • python如何实现Simhash算法
    这篇文章主要介绍python如何实现Simhash算法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、simhash步骤simhash包含分词、hash、加权、合并、降维五大步骤simhash代码如下:import...
    99+
    2023-06-29
  • Java MD5算法如何实现
    本文小编为大家详细介绍“Java MD5算法如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java MD5算法如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。MD5加密简介哈希...
    99+
    2023-07-02
  • Python如何实现KPM算法
    这篇文章主要介绍Python如何实现KPM算法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!知识点说明:先说前缀,和后缀吧比如有一个串:abab则在下标为3处的(前缀和后缀都要比下标出的长度小1,此处下标为3出的长度...
    99+
    2023-06-21
  • Java如何实现Kruskal算法
    本文小编为大家详细介绍“Java如何实现Kruskal算法”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java如何实现Kruskal算法”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。介绍构造最小生成树还有一种...
    99+
    2023-07-02
  • Java如何实现RSA算法
    小编给大家分享一下Java如何实现RSA算法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!以下是引用片段:package rsa; import java.mat...
    99+
    2023-06-03
  • PHP如何实现LRU算法
    小编给大家分享一下PHP如何实现LRU算法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!整体设计用数组保存缓存对象(Node);缓存对象(Node)之间通过nex...
    99+
    2023-06-20
  • Java如何实现Floyd算法
    本篇内容主要讲解“Java如何实现Floyd算法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java如何实现Floyd算法”吧!一 问题描述求节点0到节点2的最短路径。二 ...
    99+
    2023-07-02
  • 如何使用Python实现遗传算法
    本篇内容介绍了“如何使用Python实现遗传算法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!遗传算法是模仿自然界生物进化机制发展起来的随机...
    99+
    2023-07-05
  • 如何用 GO IDE 实现编程算法?
    在编程领域,算法是必不可少的一部分。对于程序员来说,熟练掌握算法是提高编程技能的重要途径之一。而使用一个高效的集成开发环境(IDE)来实现算法,可以大大提高开发效率和代码质量。本文将介绍如何使用 GO IDE 实现编程算法。 GO IDE...
    99+
    2023-06-30
    ide api 编程算法
  • 如何用C++实现A*寻路算法
    目录一、A*算法介绍二、A*算法步骤解析三、A*算法优化思路3.1、openList使用优先队列(二叉堆)3.2、障碍物列表,closeList 使用二维表(二维数组)3.3、深度限...
    99+
    2024-04-02
  • javascript如何实现算术加法运算
    这篇文章主要介绍“javascript如何实现算术加法运算”,在日常操作中,相信很多人在javascript如何实现算术加法运算问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作