深入浅出区块链 Day2

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

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

相关推荐
神奇小汤圆4 分钟前
SpringBoot实现微信登录,SoEasy!
后端
逍遥德10 分钟前
Maven教程.02-基础-pom.xml 使用标签大全
java·后端·maven·软件构建
神奇小汤圆37 分钟前
为什么Java里面,Service层不直接返回Result对象?
后端
Charlie_lll1 小时前
Redis脑裂问题处理——基于min-replicas-to-write配置
redis·后端
得物技术1 小时前
Sentinel Java客户端限流原理解析|得物技术
java·后端·架构
NGINX开源社区1 小时前
使用 Microsoft Entra ID 配置 NGINX Plus 以实现 SAML SSO
后端·python·flask
cipher2 小时前
crawl4ai:AI时代的数据采集利器——从入门到实战
后端·爬虫·python
摸鱼的春哥2 小时前
把白领吓破防的2028预言,究竟讲了什么?
前端·javascript·后端
@atweiwei3 小时前
rust所有权机制详解
开发语言·数据结构·后端·rust·内存·所有权
树獭叔叔3 小时前
05-从隐藏向量到文字:LM Head如何输出"下一个词"?
后端·aigc·openai