比特币交易为什么需要经过6个区块的确认
扫描二维码
随时随地手机看文章
我们常常说,一笔比特币交易需要经过6个区块的确认。
一个问题:为什么比特币交易要经过6个区块确认?
一个案例:
如下图所示,绿色和黄色是两名矿工,他们挖到了的新区块,同时向比特币网络广播公布。
地理位置靠接绿色矿工的节点,首先收集绿色矿工公布的区块。
地理位置靠接黄色矿工的节点,首先收集黄色矿工公布的区块。
所以,不同的节点,可能同时会有不同版本的区块链。而这两个版本的区块链,都被矿工继续开采。
这个时候,比特币交易的顺序不清不楚。
比特币网络,必须围绕“哪个版本的区块链,才是‘正确’的区块链?”,寻求共识。
一个规则:
共识规则是:如果出现分支,那么比特币网络上的节点继续保持两个分支,任何情况下,最长的链被确认为——“正确的”链。
一些节点收到黄色区块。另一些节点先收到绿色区块。
收到黄色区块的矿工,继续沿着他们的分支挖矿,就叫分支A。
收到绿色区块的矿工,继续沿着他们的分支挖矿,就叫分支B。
如果,分支B的矿工,先挖到下一个区块——紫色区块,向网络公布了这个消息。
分支A的矿工,注意到分支B最长,会立刻停止分支A的工作,转换到B分支。
这样,所有的矿工,又都在同一个分支上挖矿了。比特币交易的顺序统一。
这样,所有的交易,最终都会被验证。
而黄色区块里记录的交易,会继续保持待定状态,随后被放到分支B的新区块里。
过时块:
黄色区块,就被称为——过时块 (Stale block)。
是被矿工成功挖掘的块,因为不包含在最长链中,而被丢弃,等待被重新写入。
补充:
一笔比特币交易,需要经过6个区块的确认。换句话说,其后至少要有5个区块被验证。即:该交易一共有“6个确认”。6这个数字,是估算得来的。
如果作恶者想进行双重支付,那么他必须控制非常巨大的算力,才能保证他作假的信息,能写到最长的分支上。控制这么巨大的算力,几乎不可能。
6个区块的确认,给予比特币网络充分的时间,去统一所有区块的顺序。
结论:
所以,6个区块的确认,用来——确认该交易在最长分支的区块里。
来源: 区块链研习社