查看原文
其他

科普 | 什么是51%算力攻击?

白话区块链 白话区块链 2021-04-22

这是白话区块链的第1248期原创 

作者 | 晏文春
出品|白话区块链(ID:hellobtc)


关注比特币的朋友,想必听过51%算力攻击这个词,它到底是什么意思呢,发起这种攻击之后能做哪些“坏事”呢?

今天就来简单介绍一下51%算力攻击相关的事情。


 01 
什么是51%算力攻击?

比特币白皮书中,有过这样的表述:诚实节点控制算力的总和,大于有合作关系的攻击者算力的总和,该系统就是安全的。

换句说,当系统中有合作关系的恶意节点所控制的算力,超过诚实节点所控制的算力,系统就是有被攻击的风险。

这种由恶意节点控制超过50%算力所发起的攻击,称为51%算力攻击。

那是不是所有的加密货币系统都有可能遭遇51%算力攻击的风险呢?

其实并不是的,只有基于 PoW(工作量证明)共识机制的加密货币,才存在51%算力攻击,比如比特币、比特现金和目前阶段的以太坊等。


 02 
这种攻击能做哪些坏事

在了解了51%算力攻击之后,你肯定好奇,这种攻击能做哪些坏事。

1、双花(Double Spending)

双花的意思是一份"钱"花了两次甚至多次。51%算力攻击是如何做到双花的呢?

假设小黑有 666 BTC,他把这些 Token 支付的大白同时,也把这些 Token 发到自己的另一钱包地址上。

换一句话说,小黑的一份钱,同时转给两个人。最终,发给大白那笔交易先被得到了确认,并打包在区块高度为 N 的区块内。

这时,控制了超过50%算力的小黑,发起51%算力攻击。他通过重新组装第 N 个区块,将发给自己那笔交易打包进区块里,并持续在这条链上延展区块。

由于算力的优势,这条量将成为最长合法链。这样小黑666BTC双花成功,大白钱包里的 666 BTC"不翼而飞"了。

2、压制某些地址发送/接受比特币

除此之外,51%的算力攻击还能做什么呢?它还可以压制某个地址发送/接收比特币。

小黑和大白吵架了,小黑仰仗自己掌控了51%算力,他在知道大白比特币地址情况下,可以让与大白相关的交易一直无法确认。

比如大白为了向中本聪表达自己的敬意,想往"创世地址"发送 1 枚比特币。控超过半数算力的小黑,不会打包这条交易,不仅如此小黑还能做到让其他矿工也不会打包这条交易。

小黑是怎么做到的呢?

如果其他矿工挖出的新区块打包了这笔交易,小黑会选择不在这个区块之后继续挖矿,他会选择在上一个区块之后,重新构建新区块,并把大白这笔交易拒绝在外,仰仗自己算力优势,小黑分叉出的这条链,将成为最长合法链。

在这种情况下,其他矿工也就只好不打包与大白有关的交易,否则挖出的区块也会被小黑给孤立,得到出块奖励也将被作废。


 03 
小结

那拥有超过50%的算力,就可以为所欲为,什么坏事都可以做吗?其实并不是的。

即使控制超过50%的算力,也不能转移其他人的 Token,因为这个操作是需要私钥进行签名,如果想伪造签名来“偷币”,这种行为是诚实的矿工所不能容忍的,这将颠覆系统共识。

如果你掌握了某个加密货币50%以上的算力,你会发动51%算力攻击吗?为什么?快到留言区说说你的看法吧。


END

上一篇科普 | 挖矿的演变

『声明:本文为作者独立观点,不代表白话区块链立场,本内容仅供广大加密爱好者科普学习和交流,不构成投资意见或建议,请理性看待,树立正确的理念,提高风险意识。文章版权和最终解释权归白话区块链所有。』


欢迎长按二维码

阅读白话区块链入门连载

↓↓↓


喜欢请点「在看」👇

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存