Vitalik提出多维EIP1559方案,优化gas模型并增加DoS保护

原文作者:VitalikButerin

以太坊虚拟机中的许多资源都具有以下属性:它们对突增容量和持续容量有非常不同的限制。举一些例子:

EVM使用量:区块处理时间偶尔在2秒可能没问题,但是每个区块都花费这么长时间则会使保持节点同步变得非常困难区块数据:客户端有足够的带宽来处理2MB的区块,但没有足够的磁盘空间来存储它们见证数据:与数据相同的问题-客户端有足够的带宽来处理中大型见证,但没有足够的磁盘空间来存储它们填充的状态大小:基本上没有限制让状态在单个区块中增加多少只要见证人可以处理它,但我们不能在每个区块中都出现快速的状态增长我们当前使用的方案是将所有资源组合成一个单一的多维资源,在处理这些差异方面做得很差。例如,平均而言,交易数据加上调用数据会消耗区块中约3%的gas。因此,最坏情况区块包含的数据比平均情况多约67倍数据。见证的大小是相似的:平均情况下的见证只有几百kB,但最坏的情况下,即使进行了Verklegas改革,见证的大小也有几兆字节,增加了10-20倍。

Vitalik Buterin与YC创始人已在社交媒体上互相取关:11月22日消息,以太坊联合创始人Vitalik Buterin与Y Combinator联合创始人Paul Graham已在社交媒体上互相取关。以太坊联合创始人Vitalik Buterin此前发推讽刺Paul Graham的小道消息推文,并表示过去一周发现难以忍受的一个现象:人们散布谣言,很多人转发它们,很多人开始根据这些谣言信息进行交易……总之,我认为我们不应该把“Trustme”的谣言交易合法化。这为操纵市场提供了成熟的空间,甚至可能造成波动。另一个更深层次的问题是,加密领域有一段悠久的历史,人们利用谣言来诱导价格朝着有利于他们的方向波动。故意操纵市场并获取收益并不符合加密金融文化。[2022/11/22 7:55:26]

将所有资源硬塞到单个虚拟资源中会迫使最坏情况/平均情况比率变成基于使用情况,当基于使用情况的比率以及我们知道客户端可以处理的突发限制和持续限制的比率非常不一致时,会导致非常不理想的gas成本。

Vitalik Buterin:支持萨尔瓦多总统可能是加密社区犯下错误行为的一个例子:金色财经报道,以太坊联合创始人Vitalik Buterin在最新媒体采访时表示,支持萨尔瓦多总统Nayib Bukele可能是加密社区犯下错误行为的一个例子,萨尔瓦多选择了“自上而下”采用比特币的方式,比特币社区“自然而然地喜欢所有支持比特币的、有钱有势的人”,这是愚蠢的,相比之下以太坊社区在选择推广和合作对象方面做得更好。(cryptoslate)[2022/11/21 22:11:31]

本文为这个问题提出了一个替代解决方案:多维EIP1559。

假设有n个资源,每个资源都有一个突增限制bi和一个持续目标Si。我们希望任何单个区块中的资源i的数量永远不会超过bi,并且资源i的长期平均消耗等于Si。

以太坊公益组织 Nomic 基金会获 Vitalik 等捐赠1500万美元:2月12日消息,以太坊公益组织Nomic基金会于2月9日宣布正式成立,专注于改进和扩展以太坊的开发者平台,同时接管 Hardhat 和 Nomic Labs 的其他开放工程项目和相关团队,未来将继续扩展 Hardhat 工具套件。Hardhat是一个编译、部署、测试和调试以太坊应用的开发环境。

据介绍,以太坊基金会、Vitalik Buterin、Coinbase、Consensys、The Graph、Polygon、Chainlink、Gnosis、a16z、a_capital 和 Kaszek Ventures 已经向该组织捐赠 1500 万美元,其中以太坊基金会捐赠 800 万美元。接下来,该组织还将向几个 DAO 提交资金提案,以达到 3000 万美元的总资金。[2022/2/12 9:47:48]

解决方案很简单:我们为每个资源维护一个单独的EIP1559目标方案!我们维护一个基本费用向量f1...fn,其中fi是一个单位资源i的基本费用。我们设计一个硬性规则,即每个块消耗的资源i不能超过bi单位。fi由一个targeting规则调整:

Vitalik为印度新冠援救运动捐赠100个枚ETH和100枚MKR:4月25日,Polygon联合创始人Sandeep推特显示,Vitalik为印度新冠援救运动捐赠超60万美元加密货币。目前印度新冠疫情严重,Polygon联合创始人Sandeep发起了援救运动,发动加密货币圈提供帮助。根据Etherscan信息,以太坊联合创始人 Vitalik Buterin 已经捐赠已捐赠了 100 个 ETH 和 100 个 MKR。[2021/4/25 20:55:41]

为了在以太坊环境中完成这项工作,其中只有一种资源从父调用传递到子调用,我们仍然以gas收取所有费用。

选项1:我们保持执行gas成本固定,保持当前的EIP1559;让f1成为基本费用。所有“特殊”资源的gas价格变为fi/f1。区块既有当前的gas限制,也有每个资源的限制b1...bn。优先费用的运作方式与今天相同。

选项2:gasbasefee固定为1wei。使用每种资源的gas价格变为fi。没有区块gas限制;每个资源只有b1...bn的限制。在这个模型中,“gas”和“ETH”成为真正的同义词。优先费用通过指定百分比来运作;支付给区块生产者的优先费用等于basefee乘以该百分比。

多维定价与背包问题异议

历史上对多维定价模型的主要反对观点是,它们对区块构建者强加了一个困难的优化问题:区块构建者不能简单地按照每gas费用从高到低接受交易,他们必须不同维度之间平衡,并解决多维背包问题。这将为性能明显优于库存算法的专有优化矿工创造空间,从而导致中心化。

这个问题在两个关键方面已经比以前弱得多:

矿工可提取价值(MEV)已经为经过优化的矿工创造了机会,因此stock算法的“船已经出港”以有意义的方式被优化。提议者/建造者分离(PBS)解决了这个问题,将区块生产的规模经济从共识层隔离开来。EIP1559意味着任何达到限制的资源都属于边缘情况而不是平均情况,因此朴素的算法只会在少数异常区块中表现不佳。要了解为什么(2)是这种情况,我们需要注意一个非常重要的事实:在多维EIP1559中,每个资源的“松弛”参数可能远高于2x。这是因为今天的2xSlack参数创建了一个突增/持续差距,该差距叠加在来自不可预测使用的爆发/持续差距之上,而在多维EIP1559中,松弛参数代表整个突发/持续差距。例如,我们可以将calldata使用量瞄准为~256kB,在此之上有一个8倍的Slack参数,并且仍然具有与今天相当的突增限制。如果见证gas成本不变,我们可以将见证大小绑定为又一约2MB,并且见证大小的Slack参数为约6倍。对240个最新区块的调查表明,即使在4倍的calldataSlack参数下,这些区块中只有1个会达到限制!

这显示了多维EIP1559的一个很好的效果:它会使优先费用拍卖的边缘情况更加罕见,并且更快地清除突增交易。

哪些资源可以多维定价?

我们可以从基础开始:

EVM执行发送calldata见证数据存储大小增长有了分片之后,也可以将分片数据添加到此列表中。这已经给我们带来了很多好处,能够支持更多的可扩展性,同时降低突增使用带来的风险。

从长远来看,我们甚至可以使定价更加精细:

通过读取与写入拆分见证按分支与块分割见证单独定价每个单独的预编译调用每个单独的操作码这样做的主要价值在于它会增加另一层DoS保护:如果每个操作码仅被分配,例如100毫秒的最大预期执行时间,那么如果攻击者发现一个操作码或预编译的速度降低了10倍,他们只能将900毫秒的预期执行时间添加到块中。这与今天形成鲜明对比的是,他们可以使用该操作码或预编译填充整个区块,因此任何单个操作码或预编译减速10倍都可能使攻击者创建无法在单个间隔及时处理的区块。

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

银河链

[0:0ms0-1:70ms