比特币是如何解决了拜占庭将军问题
比特币其实就是一个公共的电子对账本,网络上分布着无数节点分别记录最新的交易数据。如何维护这个公共账本是这个问题的关键,也就是如何达成共识。有学者对这种问题进行了抽象就是所说的拜占庭将军问题,实际就是解决公共P2P网络如何实现信任。
拜占庭将军问题如下:
拜占庭将军问题(Byzantine Generals Problem)--
拜占庭是古代东罗马帝国的首都。强大的拜占庭将军协商一同围攻一个敌人。n个将军包围着这个敌人,他们需要协商一个一致的时间,同时对敌人发起总攻,才能确保战争的胜利。但其中一些背叛的将军可能会通过发送错误的消息造成混乱,干扰忠诚的将军同时发起总攻。如果同时发起进攻的将军数量少于m个,可怕的后果就是,拜占庭将军不仅不足以歼灭敌人,反而有可能被敌人歼灭。怎样才能保证至少有m个将军在同一时间一起发起进攻呢?
现实世界中,在互联网世界由于硬件错误、网络拥塞或断开以及遭到恶意攻击,计算机和网络可能出现不可预料的行为,是有可能发生的。那比特币系统给出了它的解决办法:
1、工作量证明;
2、奖励机制。
工作量证明:同一时间只有一个节点记账(谁算对了谁记账,解决了记账权的问题,否则大家都来记账听谁的),那如何保证他记账是准确的呢?因为所有流水帐大家都能在网络上查到,各个节点都有自己的一本帐,即是公开透明的,他要想恶意破坏,除非有51%的"同盟"一起帮他做坏。
奖励:如何能保证节点都来记账呢?系统给出奖励,谁来记账给谁奖励比特币(记账奖励),谁验证交易给谁验证奖励(验证奖励),这样节点就有动力去不停的记账和验证了,这样就共同构建了一个健壮的比特币网络。
-
VMware Workstation Pro 17官网下载安装教程 时间:2025-05-02
-
Node.js压缩包安装及环境配置 时间:2025-05-02
-
Easyconnect官网下载安装使用教程 时间:2025-05-02
-
Python中Pandas库详细教程 时间:2025-05-02
-
XPath定位方法详解(基本语法、应用场景、常见问题) 时间:2025-05-02
-
什么是时间复杂度 时间复杂度怎么计算 时间复杂度和空间复杂度的区别 时间:2025-05-02
今日更新
-
币圈百科:每个比特币地址都是唯一的么
阅读:18
-
比特币挖矿机配置要求是什么
阅读:18
-
比特币挖矿机显卡是什么-比特币挖矿机显卡寿命
阅读:18
-
原神妖刀适用角色推荐
阅读:18
-
比特币是用什么挖矿的-比特币的挖矿的原理是什么
阅读:18
-
魔兽RPG这我不乱杀攻略大全
阅读:18
-
如何产生大量的比特币地址,比特币地址的生成算法是怎样的
阅读:18
-
比特币故事之比特币是如何产生的
阅读:18
-
币圈子盘点:香港的三台比特币ATM机器具体地址
阅读:18
-
分析:比特币交易手续费具体多少钱
阅读:18