详述EIP-7706并梳理最新的Ethereum的Gas机制

时间:2024-10-01 编辑: 浏览:(345)

作者:@Web3Mario

引言:

Vitalik在2024年5月13日发布了EIP-7706提案,提出了对现有Gas模型的补充方案,将calldata的gas计算单独剥离出来,并定制了类似Blob gas的base fee定价机制,进一步降低L2的运行成本。与之相关的提案还需要追溯到2022年2月提出的EIP-4844,相隔时间甚久,因此查阅相关资料,希望对最新的Ethereum Gas机制做一个综述,方便大家快速了解。

当前已支持的Ethereum Gas模型——EIP-1559和EIP-4844

在最初的设计中,Ethereum采用了一个简单的拍卖机制对交易费用进行定价,这需要用户主动为自己的交易出价,也就是设置gas price,通常情况下,由于用户付出的交易费将归属于矿工,所以矿工将根据经济最优的原则,按照出价高低来决定交易打包顺序,注意这是在忽略MEV的情况下。在当时核心开发者看来这个机制面临着以下四个方面的问题:

交易费用水平的波动性与交易的共识成本之间的不匹配:对于处在活跃状态的区块链中,交易的打包需求充足,这意味着区块可以被轻易填满,但这往往也意味着整体费用的波动性极大。例如当平均Gas Price为10 Gwei时,网络因在一个区块中再接受一笔交易而产生的边际成本是平均Gas Price为1 Gwei时的 10 倍,这是不可接受的。

对用户来说不必要的延迟:由于每个区块有gaslimit的硬性限制,加上历史交易量的自然波动,交易通常会等待几个区块才能被打包,但这对整体网络来说是低效的;即不存在允许一个区块更大而下一个区块更小的“松弛”机制来满足逐个区块的需求差异。

定价效率低下:由于采用简单的拍卖机制导致了公允价格发现的效率较低,这意味着对于用户来说,给出一个合理的定价将是困难的,这也就意味着有非常多情况下,用户付高了手续费。

无区块奖励的区块链将不稳定:当取消挖矿带来的区块奖励并采取单纯的手续费模型时,可能会导致很多不稳定,例如激励挖掘窃取交易费用的“姐妹块”,开启更强大的自私挖掘攻击向量等。

直到EIP-1559的提出与执行,Gas模型有个第一次迭代,EIP-1559时Vitalik等核心开发者在2019年4月13日提出的,并在2021年8月5日的London升级中被采用,该机制摒弃了拍卖机制,转而采用了一种Base fee和Priority fee的双定价模型,其中Base fee将根据父区块中已产生的gas消耗情况与一个浮动且递归的gas target之间的关系通过一个既定的数学模型定量计算,直观的效果为若上一个区块中gas使用情况超过了预定的gas target时,则上调base fee,若不及gas target,则下调base fee,这样做既可以比较好的反应供需关系,又可以使得对于合理gas的预测变得更加精准,不至于出现由于误操作导致的天价Gas Price,因为base fee的计算是直接由系统决定的而非用户自由指定。具体的代码如下:

其中可知当parent_gas_used 大于parent_gas_target时,那么当前区块的base fee将相比于上一个区块的base fee加上一个偏移值,至于偏移值则是取parent_base_fee乘以上一个区块gas总用度相对gas target的偏移量并对gas target与一个常量取余与1的最大值。反之逻辑类似。

另外Base fee将不再作为奖励分配给矿工,而是直接销毁,从而时ETH的经济模型处于通缩的状态,有利于价值的稳定。而另一方面Priority fee则相当于用户给矿工的打赏,可以自由定价,这一定程度上可以让矿工的排序算法得到一定程度的复用。

随着时间推进到2021年,那时Rollup的发展逐渐进入佳境,我们知道无论OP Rollup还是ZK Rollup都意味着需要将L2的数据做压缩处理后的某些证明数据通过calldata上传至链上实现数据可用性(Data Available)或者直接交由链上做验证。这就让这些Rollup解决方案在维护L2的最终性时面临着很大的Gas成本,而这些成本最终都将转嫁到用户的身上,因此那时大部分的L2协议使用成本并没有想象那么低。

与此同时Ethereum也面临着区块空间竞争的窘境,我们知道每个区块存在一个Gas Limit,这意味着当前区块中的所有交易的Gas消耗加总不可以超过该值,按当前的Gas Limit为30000000来计算,理论上存在30,000,000 / 16 = 1,875,000字节的限制,其中16指的是EVM处理每个 calldata 字节需要消耗16单位的Gas,也就意味着单个区块最多可以承载的数据规模约为1.79 MB。而L2排序器所产生的Rollup相关数据通常数据规模较大,这就使其与其他主链用户的交易确认产生竞争,导致单个区块可以打包的交易量变小,进而影响主链的TPS。

为了解决这个窘境,核心开发者们于2022年2月5日提出了EIP-4844提案,并在2024年二季度初的Dencun升级后得到了实施。该提案提出了一种新的交易类型,名为Blob Transaction,相比于传统类型的Transaction,Blob Transaction的核心思想是补充了一个新的数据类型,即Blob data。区别于calldata类型,blob data不可以被EVM直接,而只能访问其hash,也被称为VersionedHash。此外还有两个相伴而来的设计,其一相较于普通交易,blob transaction的GC周期更短,从而保证区块数据不至于过于臃肿,其二blob data的具有原生的Gas机制,总体上呈现的效果于EIP-1559类似,但在数学模型上选择自然指数函数,使其在应对交易规模波动时稳定性上表现更好,因为自然指数函数的斜率亦为自然指数函数,这意味着无论此时网络交易规模处在什么状态,当交易规模快速飙升时,blob gas的base fee反应的更充分,从而有效遏制交易活跃度,同时该函数还有一个重要的特性,当横坐标为0使,函数值为1。

base_fee_per_blob_gas = MIN_BASE_FEE_PER_BLOB_GAS * e**(excess_blob_gas / BLOB_BASE_FEE_UPDATE_FRACTION)

其中MIN_BASE_FEE_PER_BLOB_GAS和BLOB_BASE_FEE_UPDATE_FRACTION为两个常量,而excess_blob_gas则由父区块中总的blob gas消耗于一个TARGET_BLOB_GAS_PER_BLOCK常量之间的差值来决定,当总的blob gas消耗超过目标值,即差值为正时,e**(excess_blob_gas / BLOB_BASE_FEE_UPDATE_FRACTION)大于1,则base_fee_per_blob_gas变大,反之则变小。

这样对于一些只希望利用Ethereum的共识能力为某些规模较大的数据做存证以保证可用性的场景就可低成本的执行,同时不会挤占区块的交易打包能力。以Rollup排序器为例,可以通过blob transaction将L2的关键信息封装到blob data中,并在EVM中通过精巧的设计,利用versionedHash实现链上验证的逻辑。

需要补充的是当前TARGET_BLOB_GAS_PER_BLOCK和MAX_BLOB_GAS_PER_BLOCK的设置为主网带来了一个限制,即每个区块的平均处理3 个 blob (0.375 MB) 的目标和最多6个blob (0.75 MB)的限制。这些初始限制旨在最大限度地减少该 EIP 对网络造成的压力,并且随着网络在较大区块下展现出可靠性,预计会在未来的升级中增加。

对于执行环境Gas消耗模型的再细化——EIP-7706

在明确了当前Ethereum的Gas模型后,我们来看下EIP-7706提案的目标与实施细节。该提案由Vitalik在2024年5月13日提出。与Blob data类似,该提案对另一个具有特殊性的数据字段对应的Gas模型进行了剥离,这个数据字段即为calldata。并且优化了相应的代码实现逻辑。

从原理上calldata的base fee计算逻辑与EIP-4844中base fee for blob data相同,均采用了指数函数并根据父区块中的实际gas消耗值与目标值的偏差值来计算对当前base fee的缩放比例。

值得注意的是一个新的参数设计,LIMIT_TARGET_RATIOS=[2,2,4],其中LIMIT_TARGET_RATIOS[0]表示了执行操作类Gas的目标比率,LIMIT_TARGET_RATIOS[1]表示Blob data类Gas的目标比率,LIMIT_TARGET_RATIOS[2]表示calldata类Gas的目标比率,这个向量用于计算父区块中三类gas对应的的gas target值,计算逻辑如下,即分别使用LIMIT_TARGET_RATIOS对gas limit做整除操作:

其中gas_limits的设定逻辑如下:

gas_limits[0]必须遵循现有的调整公式

gas_limits[1]必须等于MAX_BLOB_GAS_PER_BLOCK

gas_limits[2]必须等于gas_limits[0] // CALLDATA_GAS_LIMIT_RATIO

我们知道当前gas_limits[0]为30000000,CALLDATA_GAS_LIMIT_RATIO被预设为4,这就意味着当前calldata gas target约为30000000 // 4 // 4 = 1875000,又因为按当前的calldata gas计算逻辑,每个非零Bytes消耗16 Gas,零Bytes消耗4 Gas,假设某段calldata中非零与零Bytes的分布各占50%,则平均处理1 Bytes的calldata需要消耗10 Gas。因此当前的calldata gas target应对应187500 bytes的calldata数据,约为当前平均用量的2倍。

这样做的好处在于大大减少了calldata达到gas limit的情况发生的概率,通过经济模型使calldata的用量保持在一个较为始终的状态,同时也杜绝了对calldata的滥用。之所以做这样的设计还是为L2的发展扫平障碍,搭配blob data,使得排序器成本进一步降低。

最新 更多 >
  • 1 CRANE$币在哪个平台买

    介绍CRANE$币CRANE$币是一种新兴的加密货币,由CRANE公司发行。它基于区块链技术,在全球范围内得到了广泛应用。CRANE$币的目标是为用户提供更安全、便捷和匿名的交易方式。选择合适的交易平台要购买CRANE$币,您需要选择一个合适的交易平台。在选择平台时,可以考虑以下几个因素:1. 可信度:选择一家具有良好声誉和可靠的平台是非常重要的。可以通过在线论坛、社交媒体等方式查看其他用户的评价

  • 2 bkrw币值多少钱一枚

    近年来,区块链技术的快速发展带来了众多的加密货币,其中一个备受瞩目的币种是BKRW。BKRW是一种稳定币,其价值与韩国货币韩元(KRW)挂钩,使其成为数字资产市场上的热门选择。那么,BKRW币究竟值多少钱一枚呢?根据最新数据,目前BKRW的价值是1枚BKRW等于1韩元(KRW)。这意味着如果你有100枚BKRW,它们的价值就是100韩元。相比较其他加密货币波动较大的价值,BKRW币的稳定性使其成为

  • 3 CENNZ币值多少钱一枚

    CENNZ币是一种加密数字货币,它基于新西兰区块链技术研究公司Centrality推出的平台币。CENNZ币在区块链行业中具有重要的地位,因为它不仅作为交易媒介,还可以用于参与Centrality生态系统的治理和激励机制。那么CENNZ币目前的价值是多少钱一枚呢?根据币界网的数据显示,CENNZ币的价格是根据市场供需关系而定的,而市场供需关系受到许多因素的影响,如交易所的交易活动、投资者的情绪以及

  • 4 bxek币有希望吗

    BXEK币:革新与挑战并存的数字货币在当今数字货币的潮流中,BXEK币正以其独特的价值主张和创新的技术特点引起许多投资者的注意。然而,对于BXEK币究竟能否实现其承诺的讨论一直存在。在对BXEK币的前景进行深入探讨之前,我们首先需要了解其背后的技术和使命。BXEK币是一种基于区块链技术的加密货币,致力于构建一个完全分散、自由和隐私保护的金融交易系统。相比传统的中心化金融机构,BXEK币采用去中心化

  • 5 CRFI币去哪里交易

    CRFI币是什么?CRFI币是以区块链技术为基础发行的一种数字货币。作为CRF(Crypto Investment Fund)项目的核心代币,CRFI币旨在为用户提供更安全、透明和便捷的金融交易体验。CRFI币的价值受到投资者信任和项目发展进展的影响,因此在市场上引起了广泛关注。CRFI币交易所的选择对于想要交易CRFI币的投资者来说,选择合适的交易所至关重要。以下是几个可以考虑的交易所:1. A

  • 6 BITS币有风险吗

    随着数字货币的兴起,比特币(Bitcoin)已成为最知名的加密货币之一。它的价值和影响力随着时间的推移不断增加,吸引了众多投资者的关注。然而,和其他投资一样,比特币也存在一定的风险。在购买和持有比特币之前,我们必须清楚地了解这些潜在的风险。首先,比特币市场的价格极其波动。与传统的货币和股票市场相比,比特币价格的波动性要大得多。这种价格的剧烈波动可能导致投资者面临极高的风险。例如,比特币价格可能在短

  • 7 CREP币怎么交易

    CREP币的交易简介CREP币(Crypton Exchange Protocol)是一种去中心化的数字货币,旨在提供安全、快速、便捷的交易方式。它基于区块链技术,致力于构建一个透明、安全的数字资产交易生态系统。CREP币交易平台的选择要进行CREP币的交易,首先需要选择一个安全可靠的交易平台。在选择交易平台时,可以考虑以下几个因素:1. 安全性:选择一个有良好声誉和安全措施的交易平台是至关重要的

  • 8 BLID币有风险吗

    随着区块链技术的发展,数字货币(也称为加密货币)已经成为了人们关注的焦点。其中一种备受瞩目的数字货币是BLID币。然而,对于新兴的数字货币而言,投资总是伴随着风险。那么,BLID币有风险吗?我们从不同角度来探讨这个问题。首先,BLID币的风险体现在其价格波动性方面。与其他数字货币一样,BLID币的价格受到市场供需关系的影响。由于投资者的情绪、市场预期以及外部因素的干扰,数字货币的价格可能会快速波动

  • 9 COOHA币怎么买卖

    COOHA币的买卖原理与基本知识COOHA币是一种加密货币,它基于区块链技术运行。COOHA币的买卖过程与传统货币有所不同,用户可以通过交易平台进行买卖操作。在进行COOHA币的买卖之前,有一些基本知识需要了解。COOHA币的买卖平台选择在进行COOHA币的买卖之前,首先需要选择一个可靠的交易平台。可以通过搜索引擎查找一些知名的交易平台,并仔细阅读平台的评价和用户口碑。选择一个安全可靠的交易平台是

  • 10 XCH币去哪里开户

    如何开户XCH币?随着加密货币的普及,越来越多的人开始关注和投资这个领域。XCH币作为目前市场上备受瞩目的数字货币之一,吸引了不少投资者的眼球。但是,对于许多人来说,开户成为了一个问题。那么,我们该如何开户XCH币呢?下面将为大家介绍几个适合的开户渠道。选择正规的交易平台首先,我们需要选择一个正规的交易平台来开户。这是非常关键的一步,因为选择一个安全可靠的交易平台能够保障我们的资产安全。在选择交易