区块链共识机制 (Consensus)(PoW,PoS,PAXOS,RAFT,PBFT)

news2025/1/11 4:13:00

文章目录

  • Consensus
  • Proof of Work(PoW)
  • Proof of Stake(PoS)
  • PAXOS
    • Phases in PAXOS
      • Prepare Phase
      • Accept Phase
  • Replicated And Fault Tolerant(RAFT)
    • Leader Election
    • Log Replication
  • Practical Byzantine Fault Tolerance (PBFT)
    • Pre-prepare Phases
    • Prepare Phase
    • Commit Phases
  • Metrics of Consensus
    • Performance


所谓“共识机制”,是通过特殊节点的投票,在很短的时间内完成对交易的验证和确认;对一笔交易,如果利益不相干的若干个节点能够达成共识,我们就可以认为全网对此也能够达成共识。再通俗一点来讲,如果中国一名微博大V、美国一名虚拟币玩家、一名非洲留学生和一名欧洲旅行者互不相识,但他们都一致认为你是个好人,那么基本上就可以断定你这人还不坏。

百度百科

Consensus

当谈及分布式环境中的共识时,一般涉及到两种类型的节点:

  • Legitimate nodes:诚实节点,觉得你是好人,就投票你为好人
  • Malicious nodes:恶意节点,行为“恶劣”,颠倒黑白

此外,即使发生任何故障,我们的系统也必须正常运行。有两种类型的故障会发生:

  • Crash failure:诚实节点发生的故障(消息延迟、不可送达)
  • Byzantine failure:恶意节点造成的故障(篡改消息、不按套路执行协议)

因此,区块链共识协议的主要责任有:

  • 保持账本(区块链)中的数据的有序性、安全性
  • 在区块链网络中的节点之间达成协议,即提供拜占庭协议(即使出现拜占庭式的失败,也不会造成太大影响)

拜占庭协议(Byzantine Agreement)采用的方法是确保可以通过分布式的方法达成共识,即使出现了拜占庭式的失败也不会影响。“拜占庭失败”可以理解为恶意节点造成的故障。

下面列出一些著名的 DLT(分布式账本)以及它们所使用的共识算法:

DLTConsensus Algorithm UsedDescription
BitcoinPoW应用 PoW 来生产新的货币
EthereumPoW
HyperledgerPBFT如果 2/3 的成员对新的区块达成共识,那么该区块就成为区块链的一部分
ParityPoS要求矿工提供一定数量加密货币的所有权,而不要求其算力
HashgraphVirtual voting-based consensus algorithm
TezosPoS

Proof of Work(PoW)

比特币区块链的共识机制,PoW 是为公共区块链设计的。在 PoW 中,共识能否最终达成是不被保证的。在 PoW 中,矿工既是 leader node 又是 validator node。

节点通过计算随机哈希散列的数值解争夺记账权,求得正确的数值解以生成区块的能力是节点算力的具体表现,算力越高,就越有可能解得数值。计算出哈希值的节点才能够向区块链中添加区块,并获得奖励。某个节点获胜的概率为

P w i = φ i ∑ j = 1 N φ j P_{w_i}=\frac{\varphi_i}{\sum_{j=1}^N \varphi_j} Pwi=j=1Nφjφi

其中, i i i 代表每个参与节点, N N N 是节点的总数量, φ i \varphi_i φi 代表节点 i i i 的算力。

PoW 存在的问题

  • 如果某两个矿工同时解出了 PoW puzzle,就会造成所谓的 fork
  • 达成共识所需周期长
  • 耗费大量计算资源
  • 双花问题(double spending)

假如我们微信钱包里有 100 块钱的庞大资产,我们先去饭店吃了顿饭,结果微信出了 bug,这一笔钱并没有被银行同步,还留在钱包里,于是我们又能拿着同样的 100 块钱去看场电影,这就属于双花问题。在区块链系统中,由于共识机制导致区块确认时间长,用一个数字货币去进行一次交易,可以在这笔交易还未被确认完成前,进行第二笔交易,这就会造成双花问题。

PoW 的容错能力

  • PoW 可能会遭到 51% 算力攻击。当系统中有合作关系的恶意节点所控制的算力,超过诚实节点所控制的算力,系统就有被攻击的风险。
  • 可以容忍拜占庭失败
  • 可以有效抵御“女巫攻击”(Sybil Attack),即少数恶意节点构造多个虚假身份,并利用这些身份控制或影响网络的大量正常节点。

Proof of Stake(PoS)

在权益证明(PoS)类共识协议中,矿工的选择取决于每个节点携带的“权益”(如加密货币)数量,而不是其计算能力。

PoS 相比 PoW 会消耗更少的资源,缩短达成共识所需的时间。当然,PoS 也存在自己的一些问题,例如,在 PoS 中,奖励的授予方式应该是使所有节点都有平等的机会参与到采矿过程中。 否则,每次获胜的都为权益较高的矿工,每次得到奖励的也是它。而且如果有任何延迟或链接的连接问题,节点可能没有账本的最新副本,因此会导致同步问题。

下面这张图总结了 PoS 相比 PoW 的一些区别:

在这里插入图片描述


PAXOS

最基本的分布式共识(一致性)算法,允许在不可靠的通信条件下(信息可以延迟、丢失或者重复,但没有出错)对一个值达成共识。

PAXOS 的核心 idea 是,如果有一半以上的进程选择了一个值,那么依据多数人代表整体的原则,这个值就是共识。

PAXOS 中的节点

  • Proposer:提出要达成一致的值。某个选取的 Proposer 作为一个单的的 leader,提出一个新的决议,它处理客户的请求。
  • Acceptor:Acceptor 根据若干规则和条件对决议进行评估,并决定接受还是拒绝 Proposer 提出的建议。
  • Learner:获取 Acceptor 达成一致的值

Phases in PAXOS

Prepare Phase

  1. Proposer 收到客户提出的就某个值达成共识的请求;
  2. Proposer 向大多数或所有接受者发送一个消息 prepare(n)
  3. Acceptor 接收到 prepare(n) 消息,并进行回应。

在第二步中, n n n 代表 proposal number,它必须是全局唯一的,且要大于该 Proposer 之前使用过的 proposal number。如果 Proposer 没有收到来自大多数 Acceptor 的响应,那么它需要增大 n n n,重新发送。

在第三步中,如果 Acceptor 之前没有做出过任何响应,那么它会回复 promise(n) 消息,并承诺会忽略之后任何小于 n n n 的 proposal number。而如果 Acceptor 之前有做出过回应,即对某个小于 n n n 的 proposal number 回复了 promise(n) 消息,那么进一步可分为两种情况:

  • 如果它还没有收到来自之前 Proposer 的 accept 消息,那么它会存储现在更高的 proposal number n n n,回复 promise(n) 消息;
  • 如果它已经收到了来自之前 Proposer 的 accept 消息,那么它一定已经相应的回复了 accepted 消息,在这种情况下,它会把之前这个 full proposal 连同 promise(n) 消息一起回复,表明我之前已经接收过值了。

Accept Phase

  1. Proposer 等待,直到得到大多数 Acceptor 对该 proposal number n n n 的回应;
  2. 评估应该在 accept 消息中发送什么 v v v 值;
  3. 给 Acceptor 发送 accept(n, v) 消息, v v v 值是实际要达成一致的值;
  4. Acceptor 接收到 accept(n, v) 消息后,要么回复 accepted(n, v) 消息并将该消息发给所有 learners,要么直接忽略;
  5. 如果大多数 Acceptor 都接受了 v v v 值这个提议,那么就达成共识了。

第二步细节:如果 Proposer 收到的 promise 消息中有带有 full proposal 的,那么它会将 v v v 值增大,如果都没有 full proposal 的话, v v v 值可以随便选取。

第四步细节:Acceptor 接收到 accept(n, v) 消息后:

  • 如果它之前已经承诺过不接受这个 proposal number,它就会忽略这个消息;
  • 如果它之前回复过 promise(n) 了,那么它就回复 accepted(n, v) 消息并将该消息发给所有 learners。

Replicated And Fault Tolerant(RAFT)

RAFT 允许集群的重新配置,这使得集群成员的改变不需要中断服务。它还允许日志压缩,以缓解节点崩溃后缓慢重建的问题并减少消耗的存储。

一个 RAFT 集群中的节点可分为以下三种:

  • Leader:接收客户请求,组织日志复制给其它节点,并管理与 Follower 的通信
  • Follower:节点在本质上是被动的,只对远程过程调用(RPC)做出响应。它们从不主动发起任何通信,只会接受 leader 的复制日志,对 leader 言听计从
  • Candidate:尝试成为 leader 的节点,会发起投票请求

RAFT 主要包括两个阶段:

  • leader election
  • log replication

这里先将三个节点之间的状态转换图给出,具体过程可以往下看。

在这里插入图片描述

Leader Election

Leader Election 会基于一个心跳(heartbeat)机制来触发 leader 的选举过程:

  1. 所有的节点一开始都是 Follower;
  2. 如果 Follower 持续收到来自 leader 或者 candidate 的远程过程调用,那么它们只会保持自己 Followe 的身份;
  3. 如果特定时间内某个 Follower 没有收到来自 leader 的心跳包,表明 leader 可能已经失效了,那么该 Follower 就会变为 Candidate,发起新的选举,尝试变为 leader。
  4. 如果 Candidate 收到了大多数的选票,那么它就“竞选”成功,成为 leader。但如果多个 Follower 同时变为 Candidate,且它们的选票不相上下,那么此时就无法决出胜者,RAFT 为每轮选举都设置了超时时间,如果在这段时间内还没有选出新的 leader(election timeout),那么就会开启新一轮的选举过程。

不管是在 Follower 变为 Candidate 时的等待时间,还是选举时的 timeout 时间,都可能会发送这样的情况:不同 Follower 设置的等待时间或者不同 Candidate 的 timeout 时间相同,那么这一轮选举超时了,下一轮同样的 Follower 又变为了 Candidate,相同的 timeout 时间内还是没有从这些 Candidate 中还是没有选出 leader,又进入下一轮…

因此我们在实际中会将 Candidate 的 timeout 时间以及 Follower 的等待时间随机化,每轮选举后,每个 Candidate 都会让自己的任期号 += 1,这样我们每轮就可以选择任期号最大的那个 Candidate,减小冲突的概率。此外,发生冲突的选举后,Candidate 间隔下一次选举的时间也要随机化。

Created with Raphaël 2.3.0 Transition to candidate state Increment current term number Collect votes by sending `RequestVote` RPC to others If votes received from majority Become leader Send heartbeats Timeout yes no

上图中还缺少一点,如果 candidate 收到了来自 leader 的心跳包,那么说明选举结束了,它会变为 follower。

Log Replication

  1. 客户给 leader 发送请求;
  2. leader 会给该请求添加一个任期号(term)以及索引(index),使得该请求或命令在日志中能够被唯一识别,然后将该请求添加到自己的日志中;
  3. 并行地给 follower 发送 AppendEntries RPC,将新的日志项传递给 follower。
  4. 当集群中的大多数 follower 都追加了该请求后,leader 会提交该日志, 并执行指令改变状态机的状态,并返回结果给客户。它也会通过 AppendEntries RPC 告诉 follower 日志已经被提交,以便让 follower 也开始执行指令改变它们自己状态机的状态

上述过程的日志追加可看下图:

在这里插入图片描述


Practical Byzantine Fault Tolerance (PBFT)

从名字中也可以看出,PBFT 被设计用来在有拜占庭错误的情况下提供共识。

PBFT 包含三个子协议:

  • normal operation:该协议在一切正常,无错发生的情况下运行
  • view change:在 leader 节点出错的情况下运行
  • checkpointing:丢弃系统中的旧数据

PBFT 同样也有三种节点:

  • replicas:每个 PBFT 协议中的参与者(包括 leader 和 backup)
  • leader:也叫 primary,每个轮次都会有一个 leader 来与客户通信,leader 不变,则一直为同一个 view
  • backup:除去 leader 外的其它所有节点

如果想要容忍拜占庭错误,那么节点的最小数量应为 n = 3 f + 1 n=3f+1 n=3f+1,也就是说,如果要容忍 f f f 个故障,那么这个系统必须要有 n n n 个节点。只要系统中的节点数量保持 n ≥ 3 f + 1 n\ge3f+1 n3f+1,PBFT 就可以提供拜占庭容错。

PBFT 协议的执行分为 3 个阶段:

  • Pre-prepare
  • Prepare
  • Commit

Pre-prepare Phases

  1. leader 从客户端接收一个请求;
  2. 为该请求分配对应的序列号,序列号代表着请求被执行的顺序;
  3. 将该请求信息(pre-prepare message)广播到所有 backups 备份。

Prepare Phase

  1. backups 只会接收之前未接收过的序列号或者不同 view 对应的 pre-prepare 消息;
  2. prepare 消息发给所有节点。

Commit Phases

  1. 收到 prepare 消息的 replica 对消息进行验证(是否为相同的请求、view 以及序列号),直到集齐 2 f + 1 2f+1 2f+1 个验证好的消息;
  2. 广播 commit 消息给所有 replica;
  3. 如果集齐 2 f + 1 2f+1 2f+1 个到达的有效 commit 消息,说明决议通过;
  4. 执行该请求/决议
  5. 返回给客户 reply 消息,包含处理结果

下图为一个在 normal operation 协议下运行的 PBFT 基本过程,这是最简单过程,因为为了达到 n ≥ 3 f + 1 n\ge3f+1 n3f+1 的要求,系统中至少需要 4 个节点。

在这里插入图片描述


关于 RAFT 算法的最大容错节点数量是(n-1)/2,而 PBFT 算法的最大容错节点数量是(n-1)/3 的补充说明:(《深入剖析区块链的共识算法 Raft & PBFT》)

对于 RAFT 算法,它只支持容错故障节点,不支持容错作恶节点。故障节点就是节点因为系统繁忙、宕机或者网络问题等其它异常情况导致的无响应,出现这种情况的节点就是故障节点(也就是我们开头提到过的诚实节点的故障,Crash failure)。作恶节点除了可以故意对集群的其它节点的请求无响应之外,还可以故意发送错误的数据,或者给不同的其它节点发送不同的数据,使整个集群的节点最终无法达成共识,这种节点就是作恶节点(也就是我们开头提到过的恶意节点造成的故障,Byzantine failure)。

RAFT 算法只支持容错故障节点,假设集群总节点数为 n n n,故障节点数为 f f f,根据小数服从多数的原则,集群里正常节点只需要比 f f f 个节点再多一个节点,即 f + 1 f+1 f+1 个节点,正确节点的数量就会比故障节点数量多,那么集群就能达成共识。因此 RAFT 算法支持的最大容错节点数量是(n-1)/2。

对于 PBFT 算法,因为 PBFT 算法的除了需要支持容错故障节点之外,还需要支持容错作恶节点。假设集群节点数为 n n n,有问题的节点为 f f f。有问题的节点中,可以既是故障节点,也可以是作恶节点,或者只是故障节点或者只是作恶节点。如果故障节点和作恶节点都是不同的节点,那么就会有 f f f 个作恶节点和 f f f 个故障节点。当发现节点是作恶节点后,会被集群排除在外,剩下 f f f 个故障节点,那么根据小数服从多数的原则,集群里正常节点只需要比 f f f 个节点再多一个节点,即 f + 1 f+1 f+1 个节点,正确节点的数量就会比故障节点数量多,那么集群就能达成共识。所以,所有类型的节点数量加起来就是 f + 1 f+1 f+1 个正确节点, f f f 个故障节点和 f f f 个问题节点,即至少需要 3 f + 1 3f+1 3f+1 个节点。


Metrics of Consensus

IT 系统的性能和可扩展性一直是用来衡量区块链共识算法的关键非功能性指标。

Performance

Transaction Throughput

交易吞吐量被定义为区块链网络每秒钟可以处理的交易(Tx)数量。它可以通过如下公式进行计算:
T r a n s a c t i o n   T h r o u g h p u t = B l o c k   S i z e   ( B y t e s ) T r a n s a c t i o n   S i z e   ( B y t e s ) × B l o c k   T i m e   ( s e c o n d s ) {\rm Transaction\ Throughput}=\frac{Block\ Size\ (Bytes)}{Transaction\ Size\ (Bytes) \times Block\ Time\ (seconds)} Transaction Throughput=Transaction Size (Bytes)×Block Time (seconds)Block Size (Bytes)

其中,Block Time 为将一个区块添加到区块链中所花费的平均时间。

显然,区块尺寸越大,吞吐量就越高,而 Block Time 或者交易规模越大,吞吐量就越小。(固定其余两个量)

当交易大小为 500 Bytes,Block Time 为 10s 时,吞吐量随区块大小变化如下图所示:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/55264.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Ubuntu18.04开机自动启动终端并运行脚本

目录 1.创建测试脚本文件 2.添加到开机自启动 1.创建测试脚本文件 CtrlAltT打开终端在终端中输入以下指令,创建.sh文件。 touch “文件名”.sh 双击打开test.sh文件,输入以下测试代码,并保存 #!/bin/bash source /opt/ros/melodic/setu…

用于Python降维的线性判别分析

减少预测模型的输入变量数称为降维。 较少的输入变量可以产生更简单的预测模型,该模型在对新数据进行预测时可能具有更好的性能。 线性判别分析(简称LDA)是一种用于多类分类的预测建模算法。它还可以用作降维技术,提供训练数据集…

Unity 3D 导航系统||Unity 3D 障碍物

Unity 3D 导航系统 过去,游戏开发者必须自己打造寻路系统,特别是在基于节点的寻路系统中,必须手动地在 AI 使用的点之间进行导航,因此基于节点系统的寻路非常烦琐。 Unity 3D 不仅具有导航功能,还使用了导航网格&…

牛客练习赛106 药丸

牛客练习赛106 药丸 2022.12.02 与舍友四排玩了团体对抗的模式,练习赛就只有40分钟的剩余时间了。 题目描述 来源:牛客网 牛牛有 nnn 个属性,第 iii 个属性的初始值为 aia_iai​ ,牛牛想把第 iii 个属性的值变为目标值 bib_ib…

享元模式Flyweight

1.意图:运用共享技术有效地支持大量细粒度的对象。 2.结构 描述一个接口,通过这个接口Flyweight可以接受并作用于外部状态; ConcreteFlyweight实现Flyweight接口,并为内部状态(如果有)增加存储空间。Conr…

超融合时序数据库YMatrixDB与PostGIS案例

目录 什么是PostGIS PostGIS的特点 PostGIS 基础知识 OGC的WKB和WKT格式 插入数据实例 EWKT、EWKB和Canonical格式 插入数据实例 SQL-MM格式 常几何类型和函数 常用操作符 常用操作函数 OGC标准函数 管理函数 几何对象关系函数 几何对象处理函数 几何对象存取函…

Redis中的事务可以满足ACID属性吗?

前言 事务是数据库操作的最小工作单元,由一个有限的数据库操作序列构成。这些操作要么全部执行,要么全部不执行,是一个不可分割的工作单位。一键获取最先java文档。 事务在执行时,会提供专门的属性保证:原子性、一致性…

[附源码]Python计算机毕业设计Django高校学生摄影作品展示平台

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…

sentinel读取监控文件分析

主要分析的类 com.alibaba.csp.sentinel.dashboard.metric.MetricFetcher在sentinel监控数据db持久化中,更换了MetricController的存储实现,可以发现com.alibaba.csp.sentinel.dashboard.repository.metric.MetricsRepository原来只有com.alibaba.csp.s…

第4季3:Hi3518e的sensor接口引脚复用设置

以下内容源于朱有鹏嵌入式课程的学习与整理,如有侵权请告知删除。 在第2、3季的内容中,在板载系统的配置脚本即/etc/profile文件中,都有如下这句代码: ./load3518e -i -sensor ar0130 -osmem 32 -total 64 在第4季1&#xff1a…

MAC glucuronide linker-1/MAC glucuronide linker-2蛋白降解酶

ERRa_PROTAC(Cpd11,D1oonM40%)蛋白降解活性随着Linker的增长而减弱。Linker -(CHz)s-的化合物13d在浓度30 nM时能够降解58%的蛋白,浓度为100 nM时能够降解78%的ERRα蛋白,其降解活性不如 13c。Linker -(CHz)z-的13f&…

java计算机毕业设计ssm齐市疫苗管理系统w80jw(附源码、数据库)

java计算机毕业设计ssm齐市疫苗管理系统w80jw(附源码、数据库) 项目运行 环境配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff0…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java高校心理咨询管理系统0e78p

大部分步骤是 1.确定选题 选题的确定需要查阅大量的资料,要搞清楚自己大概想要研究的方向是什么。可以选择自己感兴趣的学科或者强势的学科进行研究,同时要多和毕业指导老师多交流,征求老师的意见和建议,最后确立选题。计算机专业…

面试官:你知道 Java 中的回调机制吗?

调用和回调机制 在一个应用系统中, 无论使用何种语言开发, 必然存在模块之间的调用, 调用的方式分为几种。 1.同步调用 同步调用是最基本并且最简单的一种调用方式, 类A的方法a()调用类B的方法b(), 一直等待b()方法执行完毕, a()方法继续往下走. 这种调用方式适用于方法b()执…

【论文速读】Scene Text Telescope: Text-Focused Scene Image Super-Resolution

前言 在阅读这篇文章的时候,我花费了近一周的时间在将其基本消化理解,至于为什么花费如此长的时间,我发现主要原因是我对transformer一知半解,所以在transformer中提出的名词,例如:Postion-Wise Feed-Forw…

365天深度学习训练营-第P3周:天气识别

🍨 本文为🔗365天深度学习训练营 内部限免文章(版权归 K同学啊 所有)🍦 参考文章地址: 🔗第P3周:天气识别 | 365天深度学习训练营🍖 作者:K同学啊 | 接辅导、…

视频转文字怎么操作?这三种转换方法你该学会

如今短视频让各种知识传播变得生动形象,但是视频学习对于后期的整理复习不是很便捷,现在教大家一种好用的视频知识整理方法,那就是视频转文字,可以将视频内容轻松转换为文字形式。那么就有人问了,怎样转换才更简单呢&a…

WeakHashMap 和 HashMap 的区别是什么,何时使用?

本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问。 前言 大家好,我是小彭。 在之前的文章里,我们聊到了 Java 标准库中 HashMap 与 LinkedHashMap 的实现原理。HashMap 是一个标准的散列表数据结构&…

eval()方法字符串转对象; 分别取对象属性名和属性的方法

字符串转对象 ⬇️ A是字符串 转对象: let B eval(‘ (‘ A ‘) ‘) B就是A转成的对象 取对象属性名(for ... in ... ) ⬇️ let C []; for(let key in B) { C.push(key); console.log(key); // 打印所有属性名 console.log(B[key]); // 打印所有属性值…

“元宇宙”虚拟世界的营销法则 “品牌元宇宙空间”算什么?

虚拟世界从来不缺吃螃蟹的品牌。 “元宇宙”依旧是当下品牌创新营销的重要形式,从时趣的行业观察来看,大量品牌方都有着元宇宙的营销意向,但在营销落地上存在不同的进度。一个显而易见的事实是,元宇宙不仅仅是一个虚拟的游戏空间…