V神科普的“Danksharding”到底是什么?

北京时间2月14日情人节当晚,以太坊创始人Vitalik Buterin联合以太坊基金会(EF)研究人员Dankrad Feist一起举办了一场关于扩容解决方案“Danksharding”的教育研讨会,如果你想了解区块链如何在增加“去中心化”和“安全性”属性的同时大规模实现扩容,那么这场研讨会就是一个好的切入点。

注:关于“Danksharding”对以太坊的意义,建议读者先阅读一下《一文了解以太坊的“扩容杀手锏”danksharding》这篇文章。

以下内容来自Dankrad Feist提供的《Dude, what’s the Danksharding situation‌?》PPT,如果你想观看完整的研讨会视频,可以访问以太坊基金会的官方youtube频道‌。

1、什么是旧的:

(1)数据分片;

(2)使用KZG 承诺的数据可用性;

(3)使用分离分片方案进行原始数据分片;

2、什么是新的:

(1)提议者-构建者(数据生成者)分离 (PBS);

(2)crList;

(3)2D方案;

(4)建议的架构

3、总结优点和缺点

数据分片

为Rollup和其他扩容解决方案提供数据可用性(DA);

数据的含义由应用层定义;

以太坊基础共识(全节点和验证者)除了确保数据可用外不承担任何责任;

为什么没有执行分片?与原生执行相比,rollup二层网络的效率要高100 倍,很难看出执行分片会有什么需求;

目标:提供约 1.3 MB/s 的数据可用性层和完整的分片功能(目前最大数据容量的10倍,平常容量的200倍);

自2019年底以来,数据分片一直是以太坊的目标;

数据可用性采样(DA sampling)

想知道通过 O(1) 工作获得的O(n) 数据是可用的;

思路:将数据分布到 n 个chunk分块中;

每个节点下载 k 个(随机选择的)chunk分块;

纠删码(Erasure coding)

V神:早期项目的最佳治理结构是创始人独断:V神早间发推称,早期项目的最佳治理结构是创始人独断,成熟项目的最佳治理结构有大量的用户、利益相关者参与。“Exit to community”(即随着项目发展,逐步交予社区治理)是二者兼得的一个途径。[2020/8/22]

使用 Reed-Solomon 编码(多项式插值)扩展数据;

例如,在编码率 r=0.5 时,这意味着任何 50% 的区块(d0 到 e4)都足以重建整个数据;

现在采样变得高效(例如,查询30个随机区块,如果全部可用,超过 50%不可用的概率为2 ^ (-30))

但是,我们需要确保编码是正确的;

KZG承诺(KZG Commitments)

承诺 C(f)

评估 y = f(z)

证明者可以计算证明 π(f,z)

使用C(f), π(f,z), y 以及 z,验证者可以确认f(z) = y

C(f)以及 π(f,z) 是一个椭圆曲线元素(每个48 字节)

KZG 承诺作为数据可用性根

将“KZG 根”想象成类似于 Merkle 根的东西;

不同之处在于“KZG 根”承诺了一个“多项式”(所有点都保证在同一个多项式上,而Merkle根不能保证这一点);

分离分片提案

提议者-构建者(数据生成者)分离 (PBS)

被发明用来对抗 MEV 导致的中心化趋势;

MEV意味着更成熟的参与者可以比普通验证者提取更多的价值,这对大型矿池而言意味着优势;

PBS 在一个独立的角色中“包含”了这种复杂性/中心化,并具有诚实的少数假设;

提议者(Proposer)= 验证者,诚实的多数假设意味着高度的去中心化要求;

数据生成者(Builder)= 单独的角色,诚实的少数假设,意味着去中心化只需要确保一个诚实(非审查)的数据生成者;

审查阻力方案 – crList

PBS的危险之处:一个高效的构建者(Builder)可以(以一定的经济成本)永久审查一些交易;

[注:在今天的贿赂模型中, 审查一笔交易的成本是永久贿赂所有提议人而不将这笔交易纳入的成本;]

crLists允许提议者指定构建者必须包含的tx列表,从而恢复旧的平衡;

crList(“混合 PBS”设计)

KZG 2d 方案

为什么不在 KZG 承诺中编码所有内容?

需要一个超级节点(“构建者”)来构建和重建以防失败的情况;

我们希望避免这种假设的有效性;

目标:在 d 个KZG 承诺中编码 m 个分片 blob;

如果我们天真地去这样做,那就需要m * k个样本,这样数据就太多了;

相反,我们可以再次使用 Reed-Solomon编码将 m 个承诺扩展到 2* m 个承诺;

KZG 2d 方案属性

所有样本都可以直接根据承诺进行验证(没有欺诈证明!);

恒定数量的样本确保概率数据可用性;

如果 75%+1 的样本可用:

所有数据都可用;

它可以从只观察行和列的验证器中重构;

不需要节点观察所有的情况;

执行区块和分片区块是一起构建的;

我们以前需要分片委员会,因为每个分片 blob可能无法单独使用;

现在,数据生成者的责任是使执行区块有效,并且所有分片 blob 都可用;

⇒ 验证可以是聚合的;

Danksharding 诚实多数验证

每个验证者选择 s = 2 随机行和列;

仅证明分配的行/列是否可用于整个epoch时期;

一个不可用的区块(<75% 可用)不能获得超过 2^(-2s) = 1/16 的证明;

Danksharding 重构

每个验证者都应该重构他们遇到的任何不完整的行/列;

这样做时,他们应该将丢失的样本转移到正交线;

每个验证器可以在行/列之间传输4个缺失的样本(大约 55,000 个在线验证器可保证完全重构)

Danksharding DA 采样(恶意多数安全)

未来升级

每个全节点检查方块矩阵上的 75 个随机样本;

这确保了不可用区块通过的概率< 2 ^(-30);

带宽 75*512 B / 16s = 2.5 kb/s;

优点

简单的设计:

不需要分片委员会基础设施;

不需要跟踪分片 blob 确认;

没有额外的构建者基础设施(来自执行层的同步支付取代了这一点)

可以使用现有的执行层费用市场基础设施;

执行链和分片之间的紧密耦合:

使得rollup设计更简单;

zkRollup 和执行链之间的同步调用是可能的;

分片不需要单独的 PBS;

随着数据立即被验证者集的 1/32(而不是旧分片方案中的 1/2048)确认,并在一个epoch时期内增加到完整的验证者集,抗贿赂的能力增强了;

得益于2d方案,全节点(无需运行验证器)将能通过75 个样本(2.5 kb/s)确保数据可用性,而不是 30*64=1920 个样本(60 kb/s);

新的挑战

增加了数据生成者要求:

构建32MB数据的KZG证明(需要100核,但目前正在研究CPU实现)

需要2.5 GBit/s的互联网连接来分发样本;

为数据生成者提供了更多权力,因为他们充当了执行+数据层服务提供商;

需要通过crList缓解;

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

区块分享

FTT我们能从 Solana 虫洞黑客事件中学到什么?

2022 年 2 月 2 日,将 Solana 区块链连接到以太坊的 Solana 虫洞桥被黑客入侵,窃取了超过 3 亿美元的 ETH。一周后,这起事件似乎画上了句号。然而,从这场灾难中仍有很多值得学习的地方,特别是关于跨链资产的安全性。

USDT2018与2022年市场对比 以及未来的市场展望

长期以来,加密市场都有着“四年一个周期”的说法,这一理论背后的依据众说纷纭,有观点认为是出于比特币4年减半的规律,也有观点认为是每4年一次的美国大选会刺激行情,无论个中缘由为何,2021年加密市场的参与者们都会承认,这一理论再次得到了验证——和2013与2017年一样,热潮再次席卷了整个加密市场,尽管他们背后的运行逻辑并不完全相同。

以太坊价格布局NFT的8个奢侈品品牌

不可替代的代币。这个词把世界颠倒了。你一直在互联网上阅读有关 NFT 的信息,在你走进的几乎每一次对话中都听到有关加密的信息,并在向下滚动你的提要的每张 Twitter 个人资料图片中看到它们的特色。 有史以来第一个 NFT 创建于 2014 年,尽管多年来没有得到认可,但 NFT 已成为一种新的社会规范。

TRX链游、元宇宙、GameFi和NFT之间的关系

什么是GameFi经济 GameFi 是 Game、DeFi(去中心化金融)和 NFT (Non-fungible Token)的集成,或者简称为“游戏金融与游戏内资产 NFTGameFi 游戏通常使用每个项目自己的代币进行玩家之间的交易。投资者还可以在游戏中购买 NFT(不可替代的代币)包括可定制的艺术品或角色。

[0:0ms0-0:499ms