常见共识算法简介

更新时间:2023-05-03 19:52:37 阅读: 评论:0

常见共识算法简介
1、Pow⼯作量证明
本质是谁做的洪灾 ⼯作多,谁就更有机会获得额外奖励。就是⼤家熟悉的挖矿,通过与或运算,计算出⼀个满⾜规则的随机数,即获得本次记账权,发出本轮需要记录的数据,全⽹其它节点验证后⼀起存储;
优点:完全去中⼼化,节点⾃由进出;
缺点:⽬前bitcoin已经吸引全球⼤部分的算⼒,其它再⽤Pow共识机制的区块链应⽤很难获得相同的算⼒来保障⾃⾝的安全;挖矿造成⼤量的资源浪费;共识达成的周期较长,不适合商业应⽤
应⽤案例:⽐特币
2、Pos权益证明
Pow的⼀种升级共识机制;谁持有的币龄时间越长(币龄=持有币的数量*持有币的时间),谁更有机会获取区块的记账权。根据每个节点所占代币的⽐例和时间;等⽐例的降低挖矿难度,从⽽加快找随机数的速度。
优点:在⼀定程度上缩短了共识达成的时间
缺点:还是需要挖矿,本质上没有解决商业应⽤的痛点
应⽤案例:未来币,以太坊采⽤了Pow+POS的混合机制
3、DPos股份授权证明机制
委托权益证明是让每⼀个持有⽐特股的⼈进⾏投票,由此产⽣101位代表 , 我们可以将其理解为101个超级节点或者矿池,⽽这101个超级节点彼此的权利是完全相等的。持币者投出⼀定数量的节点,代理他们进⾏验证和记账。从某种⾓度来看,DPOS有点像是议会制度或⼈民代表⼤会制度。如果代表不能履⾏他们的职责(代销 当轮到他们时,没能⽣成区块),他们会被除名,⽹络会选出新的超级节点来取代他们。
优点:⼤幅缩⼩参与验证和记账节点的数量,可以达到秒级的共识验证
缺点:整个中国传统文化作文 共识机制还是依赖于代币,很多商业应⽤是不需要代币存在的
应⽤案例:⽐特股
4、PBFT拜占庭容错算法
这是⼀种基于消息传递的⼀致性算法,算法经过三个阶段达成⼀致性,这些阶段可能因为失败⽽重复进⾏。
假设节点总数为3f+1,f为拜赞庭错误节点:
1、当节点发现leader作恶时,通过算法选举其他的replica为leader。
2、leader通过pre-prepare 消息把它选择的 value⼴播给其他replica节点,其他的replica节点如果接受则发送 prepare,如果失败则不发送。
3、⼀旦2f个节点接受prepare消息,则节点发送commit消息。
4、当2f+1个节点接受commit消息后,代表该value值被确定
优点:上述共识算法都脱离不了币的存在,系统的正常运转必须有币的奖励机制,系统的安全性实际上是由系统币的持有者维护保证。当我们区块链系统实际运⽤到商业应⽤时,由其承载的资产价值可能远远超出系统发⾏种鲜花 的币的价值,如果由币的持有者保证系统的安全及稳定性将是不可靠的。
1)系统运转可以脱离币的存在,pbft电子产品英文 算法共识各节点由业务的参与⽅或者监管⽅组成,安全性与稳定性由业务相关⽅保证。
2)共识的时延⼤约在2~5秒钟,基本达到商⽤实时处理的要求。
3)共识效率⾼,可满⾜⾼频交易量的需求。
应⽤:央⾏的数字货币、联盟和私有区块链。
PBFT的限制:
很难⽀持⼤规模⽹络节带枪的人打一城市名字 点。
在区块链中,相较于传统的pow等,pbft这种通过投票来达成共识的机制可以很好的解决包括分叉等问题的同时提升效率。但这仅仅⽐较适合于联盟链私有链,因为pbft的机制要求是⼀个封闭的集群,两两节点需要进⾏通信,通信量是O(n^2)(通过优化可以减少通信量),在公有链这种全球性的⼤环境下,既不符合封闭性的原则,同样⽆法达成这种巨⼤的通信量。现阶段⼤部分创业公司采⽤pbft的也基本上是联盟链私有链,节点数量并不是很多,采⽤pbft效率更⾼结果也更好。
5、Paxos算法
Paxos算法是⼀种两阶段算法,主要有三类⾓⾊,propor、acceptor、learner,propor提出议案,acceptor同意或拒绝,learner则是获取达成共识后的最终值。
准备阶段:
propor 选择⼀个提案编号 n 并将 prepare 请求发送给 acceptors 中的⼀个多数派;
acceptor 收到 prepare 消息后,如果提案的编号⼤于它已经回复的所有 prepare 消息,则 acceptor 将⾃⼰上次接受的提案回复给 propor,并承诺不再回复⼩于 n 的提案;
批准阶段:
当⼀个 proposor 收到了多数 acceptors 对 prepare 的回复后,就进⼊批准阶段。它要向回复 prepare 请求的 acceptors 发送 accept 请求,包括编号 n 和value(如果没有已经接受的 value,那么它可以⾃由决定 value)。
在不违背⾃⼰向其他 propor 的承诺的前提下,acceptor 收到 accept 请求后即接受这个请求。
Paxos算法适⽤于简单容错模型,即系统中只可能存在失效或故障节点,不存在恶意节点,如果失效节点数为x,则只需要未失效节点数为x+1就能维持系统的正常⼯作。
6、Raft算法
  Raft算法包含三种⾓⾊,分别是:跟随者(follower),候选⼈(candidate)和领导者(lea国际象棋规则 der)。⼀个节点在某⼀时刻只能是这三种状态的其中⼀种,这三种⾓⾊是可以随着时间和条件的变化⽽互相转换的。
  所有的节点初始状态都为follower,超时未收到⼼跳包的follower将变⾝candidate并⼴播投票请求,获得多数投票的节点将化⾝leader,这⼀轮投票的过程是谁先发出谁有利,每个节点只会给出⼀次投票。leader节点周期性给其他节点发送⼼跳包,leader节点失效将会引发新⼀轮的投票过程。
上图描述了⼀个Raft提案的执⾏过程:
  leader收到客户端发来的请求,写⼊本地⽇志,但写⼊⽇志的条⽬在提交状态机之前需要将请求发给所有follower请求验证;
  follower对收到的信息进⾏验证,验证成功后写⼊本地⽇志并返回leader验证成功标识;
  leader收到⼤部分的follower节点验证信息后,就会将当前的⽇志提交,更新节点的值,并⼴播更新所有follower节点的值,从⽽再⼀次达成共识;  Raft算法从节点不会拒绝主节点的请求,并且和Paxos⼀样只能容错故障或失效节点。

本文发布于:2023-05-03 19:52:37,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/82/521507.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:节点   共识   验证   请求   机制   算法   系统
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图