深入浅出区块链 Day2

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

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

相关推荐
神奇小汤圆2 分钟前
从两套系统到一条 SQL:SelectDB search() 搞定日志的搜索与分析
后端
考虑考虑13 分钟前
SQL语句中的模糊查询注意
后端·sql·mysql
Java编程爱好者20 分钟前
spring的logback引用application配置文件的变量
后端
李日灐30 分钟前
<1>Linux基础指令:Linux 高频指令详解 + 文件与目录认知
linux·运维·服务器·开发语言·后端·命令
lolo大魔王42 分钟前
Go语言的defer语句和Test功能测试函数
开发语言·后端·golang
rannn_1111 小时前
【Redis|高级篇3】Redis最佳实践|键值设计、批处理优化、服务端优化、服务器优化、集群还是主从
java·服务器·redis·后端·缓存
Cache技术分享1 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
前端·后端
霸道流氓气质1 小时前
SpringBoot中集成LangChain4j实现集成阿里百炼平台进行AI快速对话
人工智能·spring boot·后端·langchain4j
lolo大魔王1 小时前
Go语言的结构体
开发语言·后端·golang
说点AI1 小时前
我的 Vibe Coding 工具箱:一个人如何从零做出一个产品
前端·后端