StarkNet Alpha 在几周前登陆了主网,上线初期并没有应用费用机制,而与 L1 交互的 gas 成本实际上是由 StarkWare 补贴的。我们针对目前 StarkNet Alpha 版本提出了一种估算和收取交易费用的方式。
随着网络的不断升级,我们认为网络计算和收取费用的方式也相应地更新。我们在这里提出了一个初步的费用计算和收费方法,目的是随着 StarkNet 的发展对其进行完善。了解这些参数有助于构建者在设计他们的 StarkNet dApp 时更好地进行规划。
StarkNet 的交易成本
通常来说,一笔交易的成本由几个因素决定:
1、数据 —— 发送至 L1 的数据量:
1.1 状态差异信息
星巴克Web3平台Starbucks Odyssey测试版正式上线:金色财经报道,星巴克Web3平台Starbucks Odyssey测试版正式上线,首批候补名单成员将有3天的时间注册,注册用户可通过参与娱乐互动活动以赚取可收藏的数字旅程印章(Journey Stamp)和Odyssey积分。此外,Starbucks Odyssey每个月都将开放更多注册资格。[2022/12/9 21:32:23]
1.2 L2 → L1 信息的数量
1.3 已消耗的 L1 → L2 信息
这些数据都会在不同的 StarkNet L1 交易中以 call data 的形式发送到 L1。
2、计算成本 —— 这是针对跟踪步骤 (trace steps) 的计费,包括操作系统 (OS) 步骤 (如系统调用)。包括:
转移3000万枚XRP至Bitstamp的“巨鲸”显示为BitGo:金色财经报道,据Whale Alert此前披露数据显示,今日一个匿名巨鲸将3000万枚XRP转移到欧洲加密货币交易所Bitstamp,虽然该交易发送方被标记“未知”,但据专注于XRP的追踪平台共享信息显示,这笔资金来自于BitGo。另据Coingecko交易数据,XRP过去24小时下跌6.1%,已降至0.381792美元。(u.today)[2022/11/28 21:07:56]
L1 证明验证
L2 计算成本 (SHARP)
3、存储成本:在交易执行期间需要进行多少读/写操作。
4、交易的 L2 网络传输成本:它的调用数据和发出的事件。
目前的费用机制
Synthetix开发者:本周将开发Staking Dapp L2版本:Synthetix开发者clem发推表示:本周将致力于开发Staking Dapp L2版本,我们将不再需要使用Mintr。我们将可以在Dapp当中实现L1到L2的一键切换,无需转到另一个URL。[2021/1/18 16:25:47]
概括来讲,目前的解决方案是让用户/应用程序使用定序者 (Sequencer) 来估算接受 “交易” 所需要花费的成本:
用户要求一个新的服务 ("gas 估算服务,estimate gas service") 来估算在当前状态下运行给定 “交易” 所需的费用。该服务根据下文中的公式进行估算。这项服务由 Sequencer 公开。在内部,它将尝试根据当前的 StarkNet 状态估算处理该交易所消耗的资源。
动态 | Staking 项目锁仓总金额已突破 100 亿美金:据 StakingRewards 数据,Staking 项目的锁仓总金额已超 100 亿美元。其中,以法币本位看,锁仓金额最大的三个项目分别为:EOS(24 亿美元)、Tezos(12 亿美元),以及 Cosmos(6.57 亿美元)
需要说明的是,锁仓金额的增长并不代表项目锁仓比例增加,近期 PoS 项目的二级市场表现良好应为 Staking 项目锁仓总金额超百亿美金的主要原因。此前报道,去年 7 月至 9 月间,PoS 项目 staking 总锁仓金额从 93 亿美金骤降至仅剩 38 亿美金。(区块律动)[2020/2/8]
正如下文所解释的,这个估算值将是交易成本的首个粗略的近似值。费用本身将以 ETH (支付货币) 来指定,而 gas 价格作为估算服务的参数提供。
在这一点上,用户可以选择是否接受所估算的费用,或标记更高/更低的费用。然后,用户确定其愿意支付的费用并进行签名,这个签名也作为交易的一部分被发送到 Sequencer 中,以便执行这笔交易并添加到未来的区块中。
成本公式
对于费用的首个近似值,我们考虑了服务提供商 (sequencer 定序者 + prover 证明者) 支付的一些外部成本,如用于数据和计算的 L1 gas (上述的第 1 和 2.1 项)。计算的费用可能包括一个加价,以补偿 L1 gas 成本的波动。在这一点上,我们忽略了证明创建、存储操作和网络的 L2 成本 (上述的第 2.2、3、4 项)。
因此,在这个阶段,计算费用的公式将是:
其中:
1、gas_price 是服务中配置的 gas 价格,每 gas 单位使用多少 ETH。这个价格以后可以通过 API 查询。
2、gas_per_byte 是存储调用数据时单个字节的 gas 成本,目前为每个字节 16 gas。
3、?(msgs) 是交易从 L2 到 L1 发送的信息数量。
4、bytes_per_msg 是消息的字节数。当然,每个消息的字节数都可以不同,所以我们可以使用所有消息的平均消息字节大小。额外的 5000 gas 是用来更新一个内部计数器的。
5、?(state_dif f_items) 是该交易所做的状态差异的数量。2?31 分别代表每次存储写入时需写入两个字段元素,每个字段元素由 31 个字节组成。
6、gas_per_step 是 (L1 上) 单步验证的一个常数定价。stepstxn 是该函数执行的步骤数。
注意:该交易费成本的大头在于 L1 数据部分。这包括状态差异和消息。换句话说,与在 L1 上发布数据的成本相比,计算成本可以忽略不计。(gas_per_step << gas_per_byte)
未来的计划
这个机制在未来可能会有几种变化。
首先,我们希望进行一些优化以减少成本。具体来说,当几笔交易共享相同的证明时,它们也共享一些开销,因此会降低生产区块和验证的成本。在这种情况下,可以对原始交易的估算费用进行一些削减。
引入 volition 用于数据可用性 (即链下数据可用性),从而可以提供另一个节约成本的方式,我们希望将其纳入成本估算的因素。为基于 L2 的数据所做的存储修改可能会产生不同的成本。
当网络变得去中心化时,我们会采用其他机制和市场设计,其中细节目前正在研究中。一个例子是使用 “费用拍卖” 模式 —— 用户可以使用不同成本组成的某种线性组合进行付费,并允许 sequencer 挑选付费最高的交易。
最后,引入费用抽象将允许网络参与者使用 ETH 以外的代币进行付费。
来源 | community.starknet.io
作者 | Lior Schejter
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。