深入浅出区块链 Day2

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

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

相关推荐
冒泡的肥皂7 分钟前
MVCC初学demo(二
数据库·后端·mysql
追逐时光者10 分钟前
一款基于 .NET WinForm 开源、轻量且功能强大的节点编辑器,采用纯 GDI+ 绘制无任何依赖库仅仅100+Kb
后端·.net
鬼火儿14 分钟前
1.2 redis7.0.4安装与配置开机自启动
java·后端
逻极39 分钟前
Rust数据类型(上):标量类型全解析
开发语言·后端·rust
百锦再1 小时前
第2章 第一个Rust程序
java·开发语言·后端·rust·eclipse·tomcat·hibernate
Zhangzy@1 小时前
Rust 中的注释与文档注释实践指南
开发语言·后端·rust
像风一样自由20201 小时前
使用 Rust 开发图片切分工具:从零到发布的完整指南
开发语言·后端·rust
Mos_x1 小时前
Python爬虫---中国大学MOOC爬取数据(文中有
java·后端
半夏知半秋1 小时前
mongodb的复制集整理
服务器·开发语言·数据库·后端·学习·mongodb
码事漫谈3 小时前
C++环形缓冲区实践与注意事项
后端