Sui根据资源使用情况,使gas费计量更公平

news2025/1/12 3:59:32

Sui的大规模并行处理需要新的方式思考gas费,即网络上处理交易的成本。在我们的工作中,我们研究计算成本和指令处理,以设计一种最佳的gas费机制。准确评估gas费不仅可以提供公平的网络分摊成本和健康的运营业务模型,还鼓励开发人员使用最佳实践来确保适当的资源使用。

Sui的gas模型利用验证节点调查来设置gas价格,并确保链上交易的成本受到网络运营成本的约束。然而,定义Sui交易的具体成本因以下原因而变得复杂:每个交易包含多个指令,而网络可以同时处理多个交易。换句话说,每个交易应该花费多少gas费呢?

如果像其他只能按顺序处理交易的区块链一样对每笔交易应用一次gas费,可能会对Sui用户进行过度收费。我们的模型涉及测量指令数量、堆栈深度和内存使用,以更准确地表示网络资源使用情况。总的来说,我们的持续工作包括模拟和现实世界测试,以提供基于市场的gas价格和基于资源的gas计划,从而提供有效的gas费机制,以服务Sui的用户和网络健康。

总之,我们通过以下广泛步骤开发了Sui的gas费机制:

1. 确定计算资源使用的最佳方式

2. 设计计算成本的方法

3. 基于不同负载假设分析gas费模型

在并行处理网络上的资源使用

由于区块链是一种共享资源,gas费用反映了该资源的使用情况,以补偿验证节点维护网络的运营成本。此外,gas费会影响用户行为,鼓励谨慎使用网络,并希望阻止滥用。

许多区块链语言,如Solidity和EVM,以及Move的某些语言,使用基于字节码的计量方法,将每个独立字节码指令与特定成本相关联。在这些设置中,每个字节码成本与底层计算成本(即CPU周期)的数量精确匹配的重要性不如这些指令成本的相对大小重要。例如,如果Add指令的运行时间为1毫秒,而Div的运行时间为2毫秒,重要的是gas_cost(Div)/gas_cost(Add) ~= 2,而为gas_cost(Add)和gas_cost(Div)分配的实际底层数字则不那么重要。

在传统的区块链中,执行的总顺序是协议的一部分,将一笔交易视为对网络的独占使用是有道理的。特别是,如果一个用户运行了某些计算,那么另一个用户在前一个计算完成之前就不能运行自己的计算。在这种情况下,gas成本需要高度反映交易运行时间的相对大小,因为交易处理是一个零和游戏 — — 我有时间,所以其他人没有。

将一笔交易的定价视为单独运行可能并不准确,实际上很可能会向用户收取大量费用。

然而,在Sui上,协议包括大规模并行处理,使资源使用成为非独占。将一笔交易的定价视为单独运行可能并不准确,实际上很可能会大幅向用户收费。交易处理不再一定是零和游戏 — — 我可以有时间,成千上万甚至数十万人也可以分享相同的时间来处理他们的交易。

Sui的并行性要求我们退后一步,审查执行期间的传统基于指令的gas计量方法,以及它们是否适合这个新协议。特别是,并行性给资源使用成本增加了波动性,这要求我们采用一种模型,将类似的事物归在一起,而不是应用特定于指令的定价。例如,特定于将两个整数相加的成本和特定于将两个整数相除的成本变得不那么重要,由于并行效应,实际运行成本更难以预测。

在这个基础上,我们着手设计了一个gas费模型,旨在捕捉执行新的并行处理,使得结果模型尽可能易于理解和合理,并且最重要的是将这些收益返还给Sui的用户。开发这个模型使我们拒绝采用本质上是串行和历史的基于字节码的gas机制(该机制试图测量每个计算周期),而是设计了一个基于曲线或分层的执行gas模型。

设计Sui的gas费模型

为了得出一个准确的计算成本模型,使gas费更加公平,需要放弃可能相对容易的路径,比如测量交易时间,并研究其他计算因素。除了得到一个合理的模型,我们还需要考虑Sui的存储费用,这允许长期的链上存储。

计算成本

随着Move虚拟机天然的并行性和高效计算,执行单个指令的相对开销对于交易的整体执行时间或持续时间的重要性较小。相反,在确定准确的开销时,最重要的是执行的指令数量。只有在执行大量字节码指令之后,每个指令的实际运行成本差异对于交易的总运行时间才变得显著。

此外,为了建立一个准确反映执行实际成本的成本模型,即使对于串行执行系统,也需要克服许多挑战:

  • 繁琐和高度复杂的gas费机制难以理解、编程和准确实施
  • 一条指令的gas成本几乎可能与实际指令的执行一样昂贵
  • 同一条指令的执行时间可能会因未考虑在模型中的环境而发生显著变化(从理论上来说,这是不可能合理建模的),无论gas模型的复杂程度如何。Daniel Perez和Benjamin Livshits的研究《EVM中的资源计量攻击》深入探讨了这些挑战。

考虑到这些问题,我们开始探讨在Sui中是否有更好的gas计算成本模型。我们检查了通过计算的不同维度来粗略化成本模型的方法,而不是依赖于指令和内存的精确离散计数。此外,我们的目标是尽可能使生成的模型简单易懂,同时确保对用户公平和准确。

通过这一探索,我们得出了一个模型,根据执行期间的三个因素同时跟踪计算成本的多个不同维度:

  • 指令计数
  • 栈深度
  • 内存使用

每个维度都以不同的方式对交易资源使用产生影响,具有不同的权重,每个单位(例如执行单个指令,分配单个字节)的成本都会随着在交易执行过程中使用更多这些资源而增加。每个维度在执行过程中的成本会与步骤函数相结合。

这个新模型的核心思想是,我们不追求精确的、精确的周期计数方式,而是为交易成本定义一个相似的范围。此外,单个指令成本的重要性不如执行交易的所有指令的总成本重要。因此,这个新设计对资源成本采取更加动态的视角,即在交易中使用资源越多,资源的成本就越高。我们从Chen Ting、Li Xiaoqi、Wang Ying等研究人员的论文《面向以太坊的自适应gas成本机制,以抵御低价DoS攻击》中汲取了一些灵感。

通过以这种方式动态定价指令和资源使用,我们可以在一定范围内对资源使用进行低价定价,因为我们知道,如果超过这些界限(例如,在攻击情况下),执行过程中这些资源的动态定价最终将导致计算成本过于昂贵,以至于无法合理地利用。这种在计算使用较低的端口下低价定价资源使用的能力(例如,不到100,000条指令,不到1兆字节的总分配)允许我们鼓励“有意识的计算”的概念,同时最大程度地减少复杂性,无论是在实施、解释还是推理方面。

这个设计使得为了gas成本而优化代码的需求不那么重要。

由于在计算复杂性较低的模型下的简单性(在该模型中,每个指令的成本都是一个gas单位,每个分配都是一个gas单位),该模型易于理解并且成本低廉。这个设计使得为了gas成本而优化代码的需求不那么重要。因为每个指令的成本都是相同的,几乎不可能这样做。通过这种方式,使用我们的gas模型来鼓励正确的编程设计,摆脱对细节、单一字节码指令和晦涩的优化的关注,这些优化通常会对程序有害。同时,我们希望开发人员能够意识到他们的计算和他们在资源方面的使用,同时在计算他们的资源使用时也要公平计算。

非计算成本

除了上面描述的计算成本外,还有其他与在Sui上执行交易的总成本有关的额外成本。这些额外成本的两个主要来源是长期存储成本和gas成本舍入。存储成本通过Sui的存储基金以一种独特的方式处理。一旦我们完成执行交易,我们计算要分配给长期存储的数据,这个额外成本将被添加到执行交易的总成本中。此外,如果有人删除存储,将提供存储退款,可以减少交易的总成本,甚至可能会退款。然而,这些类型的存储退款仅在执行交易之后才会计算,因此不能对交易执行过程中可以使用的总gas成本产生影响。gas成本的舍入是由于gas计量中的步骤函数而发生的,我们将计算单元放入从1,000到5,000,000的桶中。使用不到1,000个计算单元的任何交易将被舍入到1,000个,从而产生微不足道的额外成本。

详细的Sui gas成本分析

我们设计的gas成本模型需要在实践中运作,同时也需要在理论中运作。测试涉及到查看不同合成工作负载的交易成本。特别是,给定N个指令,针对成本模型中每个指令的分配、推送和弹出的不同值,成本会是怎样的。

合成案例1:没有分配的指令

我们首先看一下最合成的工作负载,即没有分配并且不影响堆栈的指令。每个指令本质上都是一个NoP指令。下面我们可以看到随着在x轴上执行越来越多的指令,执行成本在y轴上的变化。

没有分配的指令会在某些阈值处开始上升,而不是线性增加。我们的模型使包含过多指令的交易变得昂贵,这应该会限制那些资源需求大的应用程序。

从这次测试中可以看出,正如之前讨论的,每个指令的成本不是线性的。在达到一定阈值后,收费将被乘以一个常数,使最终成本更昂贵。目标是尽可能长时间地保持成本,并同时避免拒绝服务攻击或使用网络导致类似效果的情况。

这种成本的非线性增加让我们可以在网络的大多数常见使用情况下保持成本,同时允许用户愿意支付更高费用时执行大量交易。最后,必须有一个点,资源使用不再合理,可能对系统和其他用户进行惩罚。因此,对于某些资源的使用和消耗,我们希望使成本变得非常昂贵(而不是设置严格的上限)。

合成案例2:纯分配

在第二个合成测试案例中,我们研究了一种理想情况,在这种情况下,我们在执行过程中成功地分配了内存字节,而没有执行任何指令。下图显示了沿y轴的成本,可分配多达43兆字节的内存。

纯粹的内存分配成本在某些阈值处上升,与我们之前仅使用指令的测试案例类似。然而,在这里,随着内存使用的增加,成本增加得更快。

再次,正如我们在前一个案例中看到的,随着执行过程中分配内存的增加,成本是非线性增长的。然而,与指令执行不同,内存分配的非线性扩大要高得多,因为成本的上限被触及。

在单独查看不同主要维度之后,我们现在可以看一些更加真实(但仍然是合成的)工作负载。

合成案例3:具有不同分配数量的指令

在单独查看指令和内存成本以及随着执行的指令数量的增加或内存分配的增加成本如何变化之后,我们现在可以分析当我们开始将它们放在一起时的成本情况。下图显示了不同指令计数的情况下,y轴上的成本,以及x轴上的指令数量。

在这些合成负载中,最有可能模拟真实世界使用的是内存加指令(橙色)和内存加指令(明亮蓝色)。gas成本在特定阈值之后显着增加。

值得注意的一点是,成本在一段时间内(指令数量)非常受控制,然后从那里呈指数增长。这与我们之前提到的一致,我们可以处理计算使用范围较低端的低价或高价成本,因为随着交易中的计算使用增加,计算成本将随之大幅增加,从而抵消了任何可能的低价或成本模型未考虑的计算问题。

实际测试和调整

Sui gas模型的调整和演进,无论是对于计算还是对于系统的非计算方面,都是一个不断进行的过程,在这个过程中,我们需要不断评估当前模型在现实世界中的行为,并确定开发人员和用户的痛点在哪里。我们计划继续开发一个公平而易于理解的模型,可以轻松地进行编程,尽可能不会阻碍良好的编程习惯,并激励良好的行为。

展望未来,机会成本的概念以及gas费和gas模型如何与Sui的执行并行性相关,意味着我们需要思考与交互或使用共享对象,这些对象创建了计算序列化部分的额外成本。

此外,我们将希望增加额外的成本,以涵盖交易的非计算成本,例如网络带宽。我们将研究交易大小、输入对象的数量和大小以及输入参数的数量和大小如何纳入执行交易的总成本。

Sui gas费故事的不断演进是一个持续进行的过程,我们重视社区反馈,不仅关于gas模型可以改进的地方,还有关于工具和更大的可见性以及有关交易如何使用gas的信息将是有用的地方。


关于 Sui Network

Sui是基于第一原理重新设计和构建而成的L1公有链,旨在为创作者和开发者提供能够承载Web3中下一个十亿用户的开发平台。Sui上的应用基于Move智能合约语言,并具有水平可扩展性,让开发者能够快速且低成本支持广泛的应用开发。获取更多信息:https://linktr.ee/sui_apac

官网|Twitter|Discord|英文电报群|中文电报群

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1267081.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

算法通关第十七关黄金挑战——透析跳跃问题

大家好,我是怒码少年小码。 本篇是贪心思想的跳跃问题专题,跳跃问题出现的频率很高。 跳跃游戏 LeetCode 55:给你一个非负整数数组 nums ,你最初位于数组的 第一个下标。数组中的每个元素代表你在该位置可以跳跃的最大长度。 …

java第20章节

一.线程简介 二.创建线程 1.继承Thread类 Thread类中常用的两个构造方法如下: public Thread():创建一个新的线程对象。 public Thread(String threadName):创建一个名称为threadName的线程对象。 继承Thread类创建一个新的线程的语法如下: public c…

网关路由器双栈配置中的IPv6相关选项解析

1、引言 讲知识往往是枯燥无味的,我们先从问题入手。家庭网关(光猫)、路由器是我们每个人或多或少都有所接触的2种设备。现在一般都是光纤入户,通常每个家庭配备一个光猫和一台家用路由器。 目前有许多网络服务已经提供了IPv6支…

视频监控管理平台/智能监测/检测系统EasyCVR设备列表显示不全是什么原因?该如何解决?

GB28181视频监控国标平台/视频云存储/安防监控EasyCVR视频汇聚平台,基于云边端智能协同,支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。智慧安防视频平台EasyCVR拓展性强,视频能力丰富,具体可实现视…

java中反射知识点概念

这里写自定义目录标题 1.什么是反射--动态注入?2.反射的诞生背景3.反射的意义4.反射后可以做些什么5.反射相关的主要API6.反射的优缺点7.反射和不反射基础使用8.工厂模式使用反射8.1首先我们来看看不使用反射的情况:8.2使用反射的情况: 9.Jav…

【springboot】idea项目启动端口被占用

问题 idea本地启动springboot项目端口老是被占用 解决 关闭被占用的端口进程 步骤: 1. winR打开程序框 2. 查出被占用端口的进程id netstat -ano | finderstr 端口号 例如 netstat -ano | finderstr 81013.杀死进程 taskkill /pid 进程id -t -f 例如 taskkill /pid 2…

1688 API接口的介绍丨商品详情页接口丨搜索商品列表接口

1688,作为中国领先的B2B电子商务平台,为全球的买家和卖家提供了一站式的采购和销售服务。而它的API接口,更是开放了1688平台的核心功能,让开发者能够根据自己的需求来定制和扩展商业应用。 1688 API接口的介绍 1688 API接口提供…

使用影刀指令+python实现简单的长文本乱序加密

本文意在利用影刀指令python代码,实现一种较为简单的长文本加密和解密,流程结构分为两步: 加密原理–是把字符转为列表,利用列表random模块中的shuffle函数做随机乱序。解密原理–是利用了列表的索引追踪,先前创建字典…

Vue3-目录调整

默认生成的目录结构不满足我们的开发需求,所以这里需要做一些自定义改动。 主要是以下工作: 1.删除一些初始化的默认文件 2.修改剩余代码内容 3.新增调整我们需要的目录结构 在src文件夹下创建两个新文件夹,一个叫api(请求模…

re:Invent 2023:PingCAP 荣获亚马逊云科技 2023 年度合作伙伴奖项

2023 年 11 月 27 日 – 12 月 1 日, 2023 亚马逊云科技 re:Invent 在拉斯维加斯举办,亚马逊云科技合作伙伴奖项在合作伙伴颁奖晚会上颁布, PingCAP 荣获亚马逊云科技大中华区 “2023 年度 ISV 合作伙伴” 和 “2023 年度亚马逊云科技 Market…

dockerfile文件:copy和add 异同

相同点: 复制文件或目录: 无论是 COPY 还是 ADD 都可以将文件或目录从构建上下文复制到容器中。支持源路径和目标路径: 两者都需要指定源路径和目标路径,用于指定要复制的文件或目录在主机上的位置以及在容器中的目标路径。 不同…

Re0: 从零实现一个置顶任意窗口的小工具

前言 话不多说,先上效果: 这里展示的是通过下拉框选择窗口,让窗口显示并置顶,其实还可以直接通过快捷键(先鼠标点击要置顶的窗口,再使用CTRLSHIFTT),本文涉及到的完整代码已上传到G…

【开源】基于Vue+SpringBoot的智能教学资源库系统

项目编号: S 050 ,文末获取源码。 \color{red}{项目编号:S050,文末获取源码。} 项目编号:S050,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 课程档案模块2.3 课…

现代风客餐阳台开放式一体布局,设计亮点。福州中宅装饰,福州装修

在现代家居设计中,开放式布局越来越受到欢迎。它不仅可以提升家居的空间感,还可以促进家人之间的交流和互动。这个客厅、餐厅、阳台一体化的设计,更是充分利用了空间,具有多重亮点。 01.玄关到客厅嵌入式一体式收纳柜 玄关是进入…

全国高校走进深算院:共话国产数据库产教融合生态建设

近日,由教育部高等学校计算机类专业教学指导委员会、全国高等学校计算机教育研究会主办,清华大学出版社、深圳市信息技术应用创新联盟承办的“2023全国高校走进信创企业研学活动”顺利举办。来自全国各地30余家高校的近80位院校领导、教师代表走进了深圳…

windows启动后直接进入指定程序并且不显示欢迎界面和windows桌面

windows启动后直接进入指定程序并且不显示欢迎界面和windows桌面 前言开机进入指定程序方法问题 浅尝GINA和Credential Providers关闭欢迎屏幕 前言 由于系统需求需要做到电脑开机后显示完windows加载页面就直接进入自己系统的界面,并且不显示登录欢迎页面&#xf…

【收藏】SNMP介绍及使用

热门IT课程-视频教程:文章浏览阅读49次。认证课程介绍:华为HCIA试听课程 : 华为HCIA试听课程:华为HCIA试听课程:华为HCIP试听课程:思科CCNA试听课程:思科CCNA试听课程:思科CCNA试听课…

0x00000709一键修复的解决办法,0x00000709错误的原因

在使用打印机时,你可能会遇到一些错误代码,其中之一是0x00000709。这个错误代码表示无法设置默认打印机。如果你遇到这样的问题不用担心!这篇文章将为你提供0x00000709一键修复的解决办法,帮助你解决0x00000709错误,并…

京东API接口的接入(京东工业)

在技术交流群,大家有探讨稳定获取京东商品主图、价格、标题,及sku的完整解决方案。这个引起了我技术挑战的兴趣。 目前,自己做了压测,QPS高、出滑块概率极低,API整体稳定,可满足业务场景的性能需求。 公共…

Electron+Ts+Vue+Vite桌面应用系列:sqlite增删改查操作篇

文章目录 1️⃣ sqlite应用1.1 sqlite数据结构1.2 初始化数据库1.3 初始化实体类1.4 操作数据类1.5 页面调用 优质资源分享 作者:xcLeigh 文章地址:https://blog.csdn.net/weixin_43151418 ElectronTsVueVite桌面应用系列 :这个系列包括了从桌…