详解信标链的替代性方案:基于累计式委员会的最终确定性模型_BAAS:BAAS币

来源|?ethresear.ch

作者|VitalikButerin

这是对信标链提议的一个替代设计方案,信标链可以在比较远的未来切换到这个模型(替代现在计划的CBC),它试图提供以下一些关键特性:

??在正常情况下,提供有意义的单个slot的经济确定性(即类似于Tendermint的特性)

使得即使大多数验证者参与合谋进行单个slot的重组,执行的成本也比现在高得多,从而减少共识可提取价值(consensus-extractablevalue,CEV)

??摆脱对LMDGHOST分叉选择的高度依赖,避免那些已知的缺陷,并需要引入复杂的混合分叉选择规则,以修补这些缺陷。

??有可能会使更低的最低存款额度(depositsize)和更高的验证者数变得可能

??保留经济确定性(economicfinality)最终接近于一个非常大的数值(数百万个ETH)这一特性

安全的共识算法(例如,Tendermint、CasperFFG等)。我们假设共识算法的设计是涉及slot和view(查看视图)的,即它在每个固定时间段尝试达成共识时。我们还假设它把加权的验证者集(现有的拜占庭容错共识算法要增加这一特性是很容易的)作为输入。

Messari:Cardano网络上的日均dApp交易量连续三个季度攀升:金色财经报道,Messari发布2023年第二季度Cardano报告。报告显示,Cardano网络上的日均dApp交易量连续三个季度攀升。Cardano第二季度DApp活跃度增长49.0%,日均交易量为57,900笔。Minswap和各种新的dApp为整体增长做出了贡献。Cardano自动做市商(AMM)Minswap是第二季度交易量最受欢迎的卡尔达诺dApp,5月和6月每月处理100万笔交易,环比增长167.5%。

此外,以美元计价的Cardano DeFi TVL较上一季度增长9.7%,年初至今增长198.6%。Cardano在DeFi排名中也有所上升,到2023年,所有链上的TVL从第34位上升到第21位。第二季度交易活动有所增加,日均成交量环比增长1.9%,从67,500笔增至68,800笔。[2023/8/6 16:20:53]

在下面的设计里,我们修改CONSENSUS,使得在每次的查看中,要求做最终敲定的验证者集都是不一样的。也就是说,是把CONSENSUS而不是验证者集作为函数get_validator_set(view_number:int)->Map?(其中int代表验证者余额)的输入,该函数可以生成验证者集的新查看视图。get_validator_set应该具有这样的特性,验证者集从一个视图到下一个视图最多变化1/r,其中r(r=65536)是复原周期长度。更形式化来说,我们希望是这样:

DappRadar:硅谷银行倒闭导致NFT交易量遭受重创:3月17日消息,据DappRadar 3月16日的一份报告,在3月10日硅谷银行倒闭之前,NFT交易量徘徊在6800万美元至7400万美元之间,然后在3月12日跌至3600万美元。3月9日至3月11日期间,NFT单日销售数量下降了27.9%。

根据DappRadar的数据,3月11日“活跃”的NFT交易员有11,440名,这是自2021年11月以来的最低记录。尽管交易冷淡,但“蓝筹”NFT的市场价值并未受到实质性影响,Bored Apes Yacht Club (BAYC)和CryptoPunks等收藏品的地板价仅略有下降。[2023/3/17 13:10:10]

其中,|x|返回的是x值的绝对值之和,而diff返回的是每个键值相减后的值(例如,diff({a:0.1,b:0.2},{b:0.1,c:0.3})={a:0.1,b:0.1,c:-0.3})。

在实践中,相邻的两个验证者集间的差值会包括现有验证者被扣除的余额,而新加入的验证者的比率与被扣除余额的比率相等。

隐私计算网络Oasis携手DappRadar推出50万美元生态加速器计划:2月4日消息,隐私计算网络Oasis与Dapp市场数据和分发平台DappRadar建立合作关系,双方将携手推出500,000美元生态加速器计划,参与该计划并脱颖而出的10个优质项目团队,将可各获得50,000美元的奖金以及技术、营销等方面的支持,以帮助项目成功启动和加速运作。[2022/2/4 9:31:36]

请注意,只有在之前的验证者还未做最后敲定时,1/r的最大验证者集差值函数才可用。如果之前的验证者集已经最终敲定了,CONSENSUS的实例会改变,因此get_validator_set函数的内部随机性会也会完全改变;在这种情况里,两个相邻的验证者集会变得完全不一样。

请注意,这意味着,如果两个最终敲定视图上的数值相差足够大,CONSENSUS函数现在是可能两个一起敲定的,且不会发生罚没;这是故意如此设计的,而协议的处理方法就与今天CasperFFG处理怠工惩罚一样。

机制

我们使用两级分叉选择:

SportsIcon完成550万美元种子轮融资,Dapper Labs等参投:11月25日消息,NFT体育平台SportsIcon宣布完成550万美元种子轮融资,投资者包括Dapper Labs、 AU21 Capital、Vinny Lingham、Elefund VC 、Fourth Revolution Capital、Vendetta Capital、FishDao、Techstars等。[2021/11/25 7:10:18]

??S选择?LATEST_FINALIZED_BLOCK?(最新被敲定的区块)

??从?LATEST_FINALIZED_BLOCK?开始,使用其他的分叉选择(例如LMDGHOST)来选择区块头

在每个slot都能查看一次CONSENSUS算法,将基于get_post_state(LATEST_FINALIZED_BLOCK)?产生的数据的验证者集生成函数作为一项输入。一个有效的提议必须包含一个LATEST_FINALIZED_BLOCK的有效子孙区块。只有当该部分在分叉选择中胜出,成为区块链的一部分时,验证者才会准备并给区块提议投票。

动态 | POWH 3D占据以太坊上Dapp热门排行榜榜首:据DappRadar数据,目前POWH 3D已经成为以太坊区块链上热度最高的Dapp,24h用户量达3152;之前排名前一的Fomo 3D和排名第二的IDEX交易所分别下降一位,暂列第二和第三,24h用户量分别为3082和1784。近期涌现的Fomo 3D同类合约热度均有所回落,目前只有FOMO Short仍在前十之列,排名第八。[2018/7/28]

如果CONSENSUS在某个视图中胜出了,那么该视图中被提议的区块就会成为新的LATEST_FINALIZED_BLOCK,改变未来几轮的验证者集。如果它失败了,它需要在下一个slot或view里进行下一次尝试。

注意:slot应该总是等于当前的视图编号加上之前每个成功最终敲定的验证者集的视图编号之和。

我们有以下的惩罚:

??由共识算法决定的常规罚没惩罚

??怠工惩罚:如果区块链无法做最终敲定,每个没有参与最终敲定的验证者都会受到惩罚。这个惩罚是在r/2个slot后将余额减半。

FFG替代方案:单个-slot-epoch的CasperFFG

上述设计的一个替代方案是使用CasperFFG,但要让epoch的长度等同于slot。CasperFFG的工作机制是不一样的,因为它不试图防止同一个委员会对一个区块及其子孙区块做最终敲定。为了适应这种差异,我们需要执行(i)1/4的安全阈值而不是1/3,(ii)这样一条规则:如果一个slot做最终敲定,验证者集最多替换1/4而不是完全替换。

请注意,在这样的设计中,实现一个slot(但不超过一个slot)的重组在理论上是无成本的。另外,在图表最后“直到最大最终确定性的slot"数需要增加4倍。

特性

如果一个区块被最终敲定了,其竞争区块如果要被最终敲定的话,需要发生以下其中一种情况:

??某个委员会(committee)出现问题了,≥1/3的验证者因为双重最终敲定另一个区块而被罚没

??最新近的委员会离线了,在经过r/3个slot后,委员会经过充分混洗能够最终敲定另一个区块而不会被罚没。但是,这带来了严重的怠工惩罚(≥1/3的攻击者余额)

在任何一种情况下,即使要回滚一个被最终敲定的区块也需要至少有DEPOSIT_SIZE*COMMITTEE_SIZE/3(存款额*委员会人数/3)个ETH被烧毁。如果我们设置COMMITTEE_SIZE=131,072(Eth2委员会每个slot的验证者数,理论上最大值为400万),那么这个数值就是1,398,101个ETH。

方案里的一些其他重要特性包括:

??无论有多少验证者存款了,在处理每个slot的?COMMITTEE_SIZE(委员会大小)交易时验证者的负载都很稳定

??验证者的负载会变得更低,因为当他们没有被要求加入委员会时,它们可以休眠

??休眠中的验证者可以快速退出和提款,而不会牺牲安全性。

扩展:用小型委员会进行链确认

如果为了提高效率,我们不得不缩小COMMITTEE_SIZE,我们可以作出下列调整:

??我们把“finalization(最终敲定)”更名为“confirmation(确认)”,以反映单个确认不再代表真正的最终确定性

??不同于选择最新的被确认区块,我们选择的是被确认区块最长链链头的被确认区块(但拒绝回滚由?COMMITTEE_LOOKAHEAD?确认以外的区块,因此?COMMITTEE_LOOKAHEAD?的确认就代表真正的最终确定性)

??get_validator_set?应该只能使用状态的信息,而不是?COMMITTEE_LOOKAHEAD?确认之前的信息

??view的编号应该就是slot的编号(这使得同一个验证者集试图在不同链上达成共识的情况变得更易于被推导出来,这种情况只有在打破一些确认的时候才可能发生)

这个方案保留了以上所有的特性,但它也引入了一个新特性:如果一个区块获得多个确认(例如,该区块被最终敲定了,且一条链的子孙区块又获得k-1个确认,因为共连续获得k个确认会影响该区块),那么回滚该区块就需要在多个委员会违反共识保证。这会使得来自多个委员会的安全水平得以堆积起来:回滚k个确认需要COMMITTEE_SIZE*DEPOSIT_SIZE*k/3个ETH,要达到k=COMMITTEE_LOOKAHEAD,委员会才会出现分歧。

还要注意的是,无论如何,为了p2p子网的安全,前瞻机制(lookaheadmechanism)是值得使用的,因此用它来设计是个好主意,而且如果有需要的话,可以留给客户端来决定他们要如何处理确认回滚问题。

请注意,“打破最终确定性所需的ETH"数假设了攻击者控制的验证者数相当于控制了超过总质押的ETH的一半(即数百万个ETH);这个数字是攻击者将失去的ETH。但这不等于任何拥有2,730,174,762个ETH的人都可以通过随便烧毁这些ETH就能回滚单个slot的确认。

原文链接:https://ethresear.ch/t/a-model-for-cumulative-committee-based-finality/10259

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

金智博客

[0:15ms0-6:550ms