二维码

4.3 Raft算法 - 数据结构 - 机器学习

1056 人阅读 | 时间:2021年01月15日 01:05
4.3 Raft算法 - 数据结构 - 机器学习 #daohang ul li t,.reed .riqi,a.shangg,a.xiatt,a.shangg:hover,a.xiatt:hover,a.shang,a.xiat,a.shang:hover,a.xiat:hover,.reed-pinglun-anniu,span.now-page,#daohangs-around,#caidan-tubiao,#daohangs,#daohangs li,#btnPost{background-color:#D10B04;} .dinglanyou1 h3{border-bottom:3px solid #D10B04;} #dibuer{border-top:2px solid #D10B04;}.cebianlan .rongqi h3{border-bottom:1px solid #D10B04;} #edtSearch{border:1px solid #D10B04;} #daohang .zuo ul li{border-right:1px solid #;} #daohang ul li t a{border-top:1px solid #;border-right:1px solid #D10B04;} #daohang ul li t a:hover{border-right:1px solid #;} #daohang .you ul li a:hover,#daohang .zuo ul li a:hover,.reed-pinglun-anniu:hover{background-color:#;} a:hover,.reed h6 a:hover,#dibuer a:hover,.reed .riqiding,.cebianlan .rongqi li a:hover,#pinglun-liebiao ul.fubens li.depth-1 dl dd span.shu a,#pinglun-liebiao ul.fubens li.depth-1 dl dd span.huifuliuyan a:hover,.reed-biaoti h6 span{color:#D10B04;} .reed .kan a{color:#0A0AF5;}.reed .kan a:hover{color:#D10101;} @media screen and (max-width:1492px){a.shang,a.xiat{background:none;} a.xiat:hover,a.shang:hover{background-color:#f9f9f9;background-image:none;text-decoration:none;}} var _hmt = _hmt || [];(function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?b19db5ba3b437a9e8698d2bc8fc64334"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s);})(); var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?b19db5ba3b437a9e8698d2bc8fc64334"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?2d748c9763cfc72fb7d1ccab29f0770d"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?f6d451f3f1be23f3abf240c64c469c1b"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })();

当前位置:首页 » 区块链精品文章 » 正文

(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646201", container: s }); })();
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646162", container: s }); })();

4.3 Raft算法

1189 人参与  2018年08月25日 17:23  分类 : 区块链精品文章  评论

由于Paxos太难懂、太难以实现,Raft算法应运而生。其目的是在可靠性不输于Paxos的情况下,尽可能简单易 懂。斯坦福大学的Diego Ongaro和John Ousterhout以易理解为目标,重新设计了一个分布式一致性算法Raft,并于2013年底公开发布。Raft既明确定义了算法中每个环节的细节, 也考虑到了整个算法的简单性与完整性。与Paxos相比,Raft更适合用来学习以及做工程实现。下面,笔者将以通俗易懂的方式来描述这个过程。

百花村村长一人负责对外事务。比如,县和乡两级的公文来往,公粮征收,工务摊派,税收等。

Raft是一个强Leader的共识协议。我们想象百花村是一个服务器集群,而这个集群的Leader就是村长, 村里的每户人家(follower)对应一个服务器,每户人家都保存了一个数据副本。所有的数据副本都必须保证一致性。即上级官员下到村里视察时,从每户 人家获得的信息应该是一样的。

百花村村长通过村户选举产生。谁得的票数多(简单多数)谁就当选村长。村长有任期概念(term)。任期是一直向上增长的:1,2,3,…,n,n+1,…。

这里要处理的是平票(split vote)的情况。在平票的情况下,该村村长选举失败,每户人家被分配不同的睡眠值。在睡眠期间的村户不能发起选举,但是可以投票。而且只有选举权,但是 没有被选举权。第一个走出睡眠期的村户发起新任期的选举。由于每户人家有不同长度的睡眠期,这保证了选举一定会选出一个村长,而不会僵持不下,不会出现每 次选举都平票的情况。一旦村长产生,任何针对百花村的“写”(比如政府政策宣示,普法教育)必须经过村长。

村长每天都要在村里转一圈,让所有人都看见。表明村长身体健康,足以处理公务。

村长选举出来后,要防止村长发生“故障”,必须定期检测村长是否失效。一旦发现村长发生“故障”,就要重新选举。

村长接收到上级命令,该命令数据处于未提交状态(uncommitted),接着村长会并发向所有村户发送命令, 复制数据并等待接收响应,确保至少超过半数村户接收到数据后再向上级确认数据已接收(命令已执行)。一旦向上级发出数据接收Ack响应后,表明此时数据状 态进入“已提交”(committed),村长再向村户发通知告知该数据状态已提交(即命令已执行)。

下面我们来测试各种异常情况。

(1)异常情况1

上级命令到达前,村长挂了。这个很简单,重新选举村长。上级命令以及来自外面的请求会自动过时失效,他们会重发命令和请求。

(2)异常情况2

村长接到上级命令,还没有来得及传达到各村户就挂了。这个和异常情况1类似,重新选举村长。上级命令以及来自外面的请求会自动过时失效。他们会重发命令和请求。

(3)异常情况3

村长接到上级命令,已传达到各村户,但是各村户尚未执行命令,村长就挂了。这种异常情况下,重新选举村长。新村长选出后,由于已收到命令,就可以等待各村户执行命令(也就是Commit数据)。上级命令以及来自外面的请求会自动过时失效。有可能,他们会重发命令和请求。Raft要求外部的请求可以自动去除重复。

(4)异常情况4

村长接到上级命令,已传达到各村户,各村户执行了命令,但是村长并没有收到通知,就在这时候村长挂了。这种情况类似上一种情况,新村长选出后,即可等待通知,完成剩下的任务。外部也会接到通知命令(已完成)。

(5)异常情况5

在命令执行过程中,村长身体不适,不能处理公务。因为百花村没有收到村长的“心跳”,百花村的村户就会自动选举(当前任期+1)任村长。这个时候就出现2个村长。这个时候新村长就会接过老村长角色,继续执行命令。即使原村长身体康复,也将成为普通村户。

来源:我是码农,转载请保留出处和链接!

本文链接:http://www.54manong.com/?id=96

(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646208", container: s }); })();
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646147", container: s }); })();
window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdPic":"","bdStyle":"0","bdSize":"16"},"share":{},"image":{"viewList":["qzone","tsina","tqq","renren","weixin"],"viewText":"分享到:","viewSize":"16"},"selectShare":{"bdContainerClass":null,"bdSelectMiniList":["qzone","tsina","tqq","renren","weixin"]}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];
区块链是什么  

微信号:qq444848023    QQ号:444848023

加入【我是码农】QQ群:864689844(加群验证:我是码农)

<< 上一篇 下一篇 >>
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646186", container: s }); })();
(function() { var s = "_" + Math.random().toString(36).slice(2); document.write('
'); (window.slotbydup = window.slotbydup || []).push({ id: "u3646175", container: s }); })();
搜索

网站分类

标签列表

最近发表

    (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https'){ bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else{ bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();

全站首页 | 数据结构 | 区块链| 大数据 | 机器学习 | 物联网和云计算 | 面试笔试

var cnzz_protocol = (("https:" == document.location.protocol) ? "https://" : "http://");document.write(unescape("%3Cspan id='cnzz_stat_icon_1276413723'%3E%3C/span%3E%3Cscript src='" + cnzz_protocol + "s23.cnzz.com/z_stat.php%3Fid%3D1276413723%26show%3Dpic1' type='text/javascript'%3E%3C/script%3E"));本站资源大部分来自互联网,版权归原作者所有!

jQuery(document).ready(function($){ /* prepend menu icon */ $('#daohangs-around').prepend('
'); /* toggle nav */ $("#caidan-tubiao").on("click", function(){ $("#daohangs").slideToggle(); $(this).toggleClass("active"); }); });

©著作权归作者所有:来自ZhiKuGroup博客作者没文化的原创作品,如需转载,请注明出处,否则将追究法律责任 来源:ZhiKuGroup博客,欢迎分享。

评论专区
  • 昵 称必填
  • 邮 箱选填
  • 网 址选填
◎已有 0 人评论
搜索
作者介绍
30天热门
×
×
本站会员尊享VIP特权,现在就加入我们吧!登录注册×
»
会员登录
新用户注册
×
会员注册
已有账号登录
×