news 2026/5/12 6:51:52

【PBFT算法】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【PBFT算法】

口信消息型拜占庭问题之解的局限

该算法存在两个主要问题:

  • 消息复杂度高:将军数为n、叛将数为f时,算法需要递归协商f+1轮,消息复杂度为O(n^(f+1))。例如叛将数为64时,消息数量远超int64表示范围。
  • 理论化严重:算法仅关注忠将达成共识,不关心共识结果是否合理(如适合进攻时可能达成撤退共识)。

PBFT算法的核心原理

PBFT通过签名约束恶意节点行为,基于三阶段协议和大多数原则(2f+1)实现共识:

三阶段协议

  1. 预准备阶段:主节点广播预准备消息给备份节点。
  2. 准备阶段:备份节点广播准备消息,确认收到一致的指令。需收到2f个一致消息才进入下一阶段。
  3. 提交阶段:节点广播提交消息,收到2f+1个验证通过的消息后执行指令。

关键点

  • 签名机制:防止伪造消息,确保消息来源和内容可信。
  • 客户端验证:客户端需收到f+1个相同响应才确认共识达成。
  • 视图变更:主节点作恶时,通过轮换机制选举新主节点。

消息复杂度优化

PBFT将消息复杂度从O(n(f+1))降至O(n2),但仍需较多消息。例如13节点集群(f=4)需237条消息,适用于中小型系统。

适用场景

  • 联盟链:如Hyperledger Sawtooth、Zilliqa。
  • 相对可信环境:能容忍(n-1)/3个恶意节点,不依赖算力(与PoW对比)。

思考题答案

客户端需收到f+1个响应才能确保至少一个来自忠将。若仅收f个响应,可能全来自叛徒,导致错误共识。

对比其他算法

  • Raft:不适用恶意节点场景。
  • PoW:消耗算力,PBFT更高效但规模受限(O(n^2)复杂度)。

通过PBFT,苏秦可确保忠将们一致执行指令,即使存在叛徒干扰。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/11 9:18:40

“Zookeeper Java客户端全解析:面试必知!”

文章目录Zookeeper的Java客户端都有哪些?引言:为什么我们要聊ZooKeeper的Java客户端?第一部分:官方推荐——Curator1.1 Curator是什么?1.2 Curator的特点1.3 Curator的使用示例1.4 Curator的优缺点第二部分&#xff1a…

作者头像 李华
网站建设 2026/5/11 1:25:38

选它还是它?Chubby与ZooKeeper深度对比

文章目录Chubby 是什么?和 ZooKeeper 比,你觉得怎么看待它们?一、Chubby 是什么?1. Chubby 的设计理念2. Chubby 的核心功能3. Chubby 的优缺点优点:缺点:二、ZooKeeper 是什么?1. ZooKeeper 的…

作者头像 李华
网站建设 2026/5/11 9:18:09

2024年WPS365版-模拟训练系统-中级模拟二

2024年WPS365版-模拟训练系统-中级模拟二 单选题 1/33 在 WPS 文档窗口中,要应用一个已有的样式,先选定要应用样式的内容,然后()。 A、单击【插入】选项卡中的【样式】按钮 B、单击【开始】选项卡中的【格式化】按钮 C…

作者头像 李华
网站建设 2026/5/11 9:19:15

揭秘原子操作:Java并发编程的高效技巧

文章目录 揭秘原子操作:Java并发编程的高效技巧一、原子操作的基本概念:什么是原子操作?原子操作的特性 二、从JVM层面理解原子操作内存屏障:原子操作的幕后英雄多核处理器的挑战 三、Java中的原子操作:从理论到实践为…

作者头像 李华
网站建设 2026/5/11 9:18:40

AssetStudio完整指南:Unity资源提取与管理的终极解决方案

AssetStudio完整指南:Unity资源提取与管理的终极解决方案 【免费下载链接】AssetStudio AssetStudio is a tool for exploring, extracting and exporting assets and assetbundles. 项目地址: https://gitcode.com/gh_mirrors/as/AssetStudio AssetStudio作…

作者头像 李华