区块链是一个存在于互连网中的大型分散式系统,存在于每一个网路参与者的电脑中。
换句话说,一但区块链要进行版本更新或系统修改,所有网路参与都必须下载并运行新版本的区块链客户端,区块链系统才能完成版本更新。
然而,分布式共识系统升级时困难的地方在于,很难要求网路参与者在同一时间完成更新,只要有参与者没有即时更新客户端,网路上就会存在不同版本的区块链,换句话说,区块链会出现分叉。
区块链更新产生的共识问题
因此,区块链进行更新时,必须协调好所有的系统参与者,否则可能会影响到区块链系统的安全性。
另一个分布式共识系统升级困难的地方在于,必须让所有网路参与者达成共识。
如果只有一部分矿工同意更新,另外一部分旧矿工不同意更新,矿工之间便会产生共识问题。
而区块链更新时的共识问题大致上会有以下四种可能:
安全团队:稳定币DEI被盗资金目前存在黑客地址:金色财经报道,据区块链安全审计公司Beosin旗下Beosin EagleEye安全风险监控、预警与阻断平台监测显示,2023年5月6日,DEI项目遭到攻击总共约损失超600万美元,被盗资金目前存在黑客地址。
Beosin安全团队分析原因是DEI代币合约中存在一个burnFrom函数,该函数在获取用户授权值的时候,将两个地址参数写反,导致获取的授权值为黑客可操控的值。扣除销毁数量后,函数将授权值更新为了一个错误的授权值,使得黑客可以直接将pair中的DEI代币转移出去并将稳定币兑换出来。
BSC交易:0xde2c8718a9efd8db0eaf9d8141089a22a89bca7d1415d04c05ba107dc1a190c3
Arbitrum交易:
0xb1141785b7b94eb37c39c37f0272744c6e79ca1517529fec3f4af59d4c3c37ef[2023/5/6 14:46:00]
1)新矿工接受旧矿工挖出的区块
比特币核心开发者寻求FBI追回被盗BTC:金色财经报道,比特币核心开发者Luke Dashjr已请求联邦调查局(FBI)协助他追回在新年前夜从他的存储钱包中被盗的价值360万美元的数字资产。
据悉,比特币核心开发者Luke Dashjr在社交媒体披露自己PGP密钥泄露导致200枚BTC被盗,金额约合360万美元。此外,Luke Dashjr还提醒加密社区暂时不要下载Bitcoin Knots应用程序,包括这款应用的更新版。[2023/1/4 9:51:59]
2)新矿工不接受旧矿工挖出的区块
3)旧矿工接受新矿工挖出的区块
4)旧矿工不接受新矿工挖出的区块
硬分叉
新矿工产生的区块可以兼容旧矿工产出的区块,而旧矿工产生的区块无法兼容新矿工产出的区块。
硬分叉与软分叉-硬分叉
OpenSea旧合约发现漏洞,未取消Wyvern协议授权的用户存在NFT被盗风险:10月28日消息,浏览器安全插件Pocket Universe发推称,Opensea旧合约上发现一个新漏洞,可用于窃取用户的NFT,一旦签署交易就可能被清空钱包。它可以盗取用户在2022年5月之前在Opensea上列出的任何NFT(也即Seaport升级之前),主要涉及Wyvern协议,它授予了代理合约撤回用户NFT的权利,而这个新的漏洞利用会诱使用户签署交易,让攻击者拥有用户的代理合约的所有权。
慢雾创始人余弦转推称,需要警惕这个老问题新利用,与OpenSea旧协议有关,但旧协议许多用户并没都取消相关授权,该利用对OpenSea新协议(Seaport)无效。[2022/10/28 11:53:00]
当系统中出现了新版本的更新,并且和前版本不能兼容,旧矿工无法接受新矿工挖出的全部或部分区块,区块链就会出现硬分叉。
公告 | FUSION将采用销毁及回购方式处理余留在Hotbit交易所的被盗资产:今日,交易所Hotbit发布公告称,2019年9月29日,Fusion团队与Hotbit团队共同努力,在盗币事件发生之后短时间内冻结了相关盗币账户,截获流入Hotbit的一批被窃资产。经双方团队协商,决定将被窃资产中260,231枚未售出FSN全部销毁,被窃资产中未能提走的剩余价值98,934.24 USDT将被用于在未来15天内于Hotbit市场上进行不定期回购。[2019/10/31]
以比特币为例,若更改协议的重要参数,例如区块大小、挖矿题目的难度或出块速度等,这些规则中的任何一个的更改都可能导致新区块无法被前版本的共识规则接受。
例如,如果更新后,区块容量限制从1MB增加到4MB,则运行新版本的矿工将接受4MB的区块,但运行旧版本的矿工则会拒绝该块。
1
社群达成共识
硬分叉与软分叉-达成共识
在新矿工占有大部分算力的情况下,旧矿工有两个选择,第一种就是接受更新并升级客户端软体,这个情况意味著社群对版本更新达成共识,区块链可以安全且顺利完成更新。
2
社群无法达成共识
硬分叉与软分叉-无法达成共识
如果就矿工坚持维护旧版本的系统,那区块链将因此分裂为两条链。(在这个情况下,新矿工与旧矿工已经无法达成共识了,即便接受更新的新矿工算力>51%,旧矿工依然不愿意接受新版本,因此不适用“最长链共识”。)
若大部分的人都选择更新,那新版本的算力势必比较强,剩下的就看旧版本的算力够不够支持维护一条链的安全,倘若还是有一定数量的矿工坚持维护旧版本,那区块链就会分裂成两条链。
当区块链分裂为两条链,且在有各自的矿工维护各自的链的情况下,就会产生两种不一样的币,这就是所谓的“分叉币”。
例如比特币社群在2017年的扩容方案理念产生分歧,无法达成共识导致硬分叉,比特币现金(BitcoinCash)因此诞生。
对用户而言,这种社群分裂的硬分叉,最有感的就是可以领分叉币,举个例子,分叉前你在钱包有“1BTC”,分叉后你将拥有“1BTC+1BCH”。
在没有得到所有生态中的参与者同意的情况下,硬分叉有很大的风险,很容易导致该区块链的生态系分裂、算力分裂以及陷入重放攻击的危险中。
所以这是一种极具争议和危险的区块链升级技术,因此区块链社群对于硬分叉非常谨慎。
软分叉
在新矿工算力>51%时,新矿工产生的区块不能兼容旧矿工产出的区块,旧矿工可以兼容新矿工产出的区块。
硬分叉与软分叉-软分叉
如果以“更严格的规则”进行更新,实现协议修改或添加不影响结构的功能时,则旧矿工将接受新矿工所产的区块;
相反的,由于新矿工所认定的协议较严格,新矿工将会拒绝旧矿工所产的区块,此时旧矿工在正常情况下,会选择升级,否则其所产的区块会无法被新矿工接受,无法获得挖矿奖励。
遇到例如意识形态或开发观点不同等特殊情况时,旧矿工仍然有可能会选择不接受新矿工产出的区块,继续维护旧版本的链,进而导致硬分叉甚至分裂。
以比特币为例,理想的情况是,旧矿工会意识到他们的区块被拒绝了,便会选择升级。
随著越来越多的矿工升级,这将进一步孤立旧版本的区块,在利益的驱使下,会诱使更多旧矿工升级,于是,系统便能以较温和的方式完成更新。
例如,社区决定将块大小从目前的1MB限制减少到0.5MB。
占多数的新矿工会拒绝旧矿工产出的1MB区块,并选择其他矿工产出的符合条件的区块。
软分叉的更新时常发生。
最初比特币没有区块大小的限制,是在之后透过软分叉引入1MB的限制,还通过软分叉成功添加了pay-to-script-hash函数,该函数在不改变结构的情况下增强了代码。
这种类型的更新通常只需要大多数矿工进行升级,其他矿工便会随之升级,这使得它更可行,破坏性更小。
链金研究员总结
软分叉与硬分叉相比,软分叉的过程中,在正常情况下,只会存在一条链,没有分成两条链的风险,且软分叉不要求所有矿工同一时间升级,而是以较温和的方式逐步升级,不影响软分叉过程中的系统稳定性和有效性。
然而两者并没有孰优孰劣之分,而是适用性的问题,假如进行大规模的区块链更新,势必会牵涉到不被旧协议接受的规则。
即便我们都知道软分叉比硬分叉来的安全,还是只能选择以硬分叉进行区块链升级。
不过也不需要把硬分叉想得太过可怕,因为只要全网矿工对升级有相同的共识,就不会分叉成两条区块链,影响到安全性。
总归一句,对区块链升级而言,重要的不是硬分叉还是软分叉,而是矿工与矿工之间的共识是否一致,这部分称之为“区块链治理”。
若共识处理不好则容易导致革命,这也是为什么区块链的升级相较传统软体还要来的困难。
投资有风险,本文观点和意见仅代表作者本人,并不构成任何建议。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。