深入浅出区块链 Day2

双花攻击是指一个代币被花费了两次,这在任意的区块链系统中是不被允许的。如果避免了双花问题,基本就能避免上述作弊中收益过大的问题,因为攻击者首先要窃取到你的私钥,同时又能控制了你的计算资源(算力)。

所有记账节点都会遵循以下两条规则: 规则一:一个代币如果已经被花费,那么会被标记成已花费,如果再次接收到这个代币被花费的请求,那么记账节点会拒绝打包这笔交易; 规则二:如果同时接收到两个信封,这两个信封中装的两笔交易出现了一个代币被花费了两次的情况,这种情况也就是我们所说的分叉(Fork),那么选择挖矿难度比较大的那个信封。 规则一避免了未确认的交易出现双花,规则二基本避免已经确认的交易中(信封中)的双花问题。 假设作弊者的计算资源(算力)占整个系统的 30%,那么连续两次获得记账权的概率是 9%,看起来作弊的可能性还是挺高的,如果是连续 6 次获得记账权呢?概率直降到万分之七。

相关推荐
zhenxin012210 分钟前
GitSubmodule避坑指南:从入门到精通
spring boot·后端·spring
_Evan_Yao13 分钟前
缓存金字塔上的红色闪电:Redis 如何借力 CPU 的 L1/L2/L3 与 TLB 飞驰
java·数据库·redis·后端·缓存
0xDevNull1 小时前
分布式事务实战指南:从理论到Seata落地
java·开发语言·后端
sghuter1 小时前
数字资源分发的技术架构与未来趋势
c语言·开发语言·后端·青少年编程
Java编程爱好者1 小时前
深入解析 OpenJDK 17 在 Linux 上的线程创建机制
后端
Gopher_HBo1 小时前
数组和切片实战
后端
卷无止境1 小时前
过度设计如何避免(java举例)
后端
派星1 小时前
PageHelper 与 MyBatis 的分页查询协作原理
后端
卷无止境1 小时前
AI编程时代,什么需求使用rust开发最合适?
后端
lagrahhn2 小时前
ES索引的基础和进阶内容
后端·elasticsearch·搜索引擎