以太坊协议所面临的一个最为长久且尚未解决的挑战,就是由于状态数据规模不断增长而带来的问题。以太坊区块链上的许多操作都会给以太坊添加状态内容,而所有全节点都必须存储全量的状态数据,这样才能验证新区块以及制造新区块。这些操作只需事务的发送者一次性缴交按gas用量来计量的手续费,但会给整个网络造成永久的持续性成本,因为节点需要存储这些新数据。
这是系统设计中的一个显著的失衡,可能会让以太坊系统变得越来越难用,因为状态中充斥着不再有用处的“垃圾数据”。本文的目的是详细解释问题产生的根源,以及一些解决该问题的方法。如果我们能实现某个解决方案,这将为安全地大幅提高区块Gas上限铺平道路。
本文所论述的研究领域仍在推进中,随时有可能出现更新、更好的想法和更优雅的权衡。
引言:问题出在哪?
“状态”指的是节点若想处理新产生的区块和事务就必须存有的信息。状态与“历史”完全不同,后者是关于过去时间的信息,节点可以保存这些信息以便日后重新广播或归档,但并不是处理区块链所必需的。
观点:区块链能让支付服务更加高效 需要行业竞争以改变数字货币角色:加密行业专家表示,随着在线支付公司Wirecard本月进入破产程序,主流金融服务商,如VISA、PayPal和Mastercard都在争先恐后地填补数字支付的空白,并成为第一家提供加密支付卡的公司。区块链服务提供商TAAL首席执行官Jerry Chan和虚拟货币平台Coincurve总裁兼联合创始人Rod Hsu都认为,要改变数字货币被用作支付或技术手段的方式,这个行业所需要的正是竞争。Jerry Chan指出,除了主流加密意识需要之外,区块链还能让支付服务更加高效。Rod Hsu表示,在Wirecard事件之后,加密部门应该学习“透明度”。他补充说,区块链是一种不可改变的开放技术,可以在“任何时候”对资金流动进行全面审计。(Cointelegraph)[2020/9/6]
在以太坊协议中,状态信息包括:
观点:如果加密货币被禁止,就不会发生Twitter黑客事件:纽约杂志商业专栏作家Josh Barro在推特上分享了他对加密的负面看法,此前多个大V推特账户被黑,并发布比特币相关钓鱼信息。Barro因此对加密货币进行了猛烈抨击:“加密对社会有害。”其表示,如果加密货币被法律正式禁止,没有人会担心坏人侵入知名人物的Twitter账户,然后以此来取比特币。他还指出加密货币对社会没有任何好处,而且在一些情况下带来了弊端,例如成为暗网的途径。(U.Today)[2020/7/17]
账户的ETH余额和nonce
智能合约的代码
智能合约的存储项
与共识机制相关的数据
历史信息则由旧的区块和收据组成。EVM中没有操作码可以让你访问旧区块、旧事务和内容和收据输出,所以节点丢弃这些数据也仍然能验证新区块,所以这些是历史信息。
观点:S2F模型显示比特币可能在2021年年中达到7万美元:加密货币评级机构韦氏评级(Weiss Ratings)分析师Bruce Ng和Juan M. Villaverde表示,S2F模型现在显示,比特币价格可能在2021年年中达到7万美元。“虽然基于与Weiss加密货币周期模型不同的方法,但S2F模型在加密世界广受尊重。现在看来,在未来12个月左右的时间里,比特币将出现强劲反弹。”黄金目前的S2F为62,而比特币的S2F为56,这意味着比特币在避险投资方面可能会与黄金相媲美。
两位分析师表示,宏观经济因素也有利于BTC,美联储在过去13周里印刷2.9万亿美元的新纸币。当投资者对纸币失去信心时,有可能转向投资比特币。另外,机构资金大量流入比特币。对冲基金巨头Paul Tudor Jones投资2.1亿美元BTC。灰度比特币信托基金继续以比BTC铸造速度更快的速度购买。而风险资本家Andreessen Horowitz最近推出5.15亿美元的新基金,用于投资加密网络和业务。(The Daily Hodl)[2020/7/10]
上述状态信息列表中的最后一项——共识机制相关数据——在设计上已经精心限制了其规模,因此我们不太需要为此困扰。但前面三项,就令人头大了。这三类状态信息的规模会随着时间推移而不断增大,因为不断会有新用户加入网络,他们会创建新的账户、新的合约,还会加入合约、收到token什么的。
观点:稳定币在支付方面或许优于比特币 但这种情况可能不会持续太久:稳定币提供了比特币的大部分好处,但没有任何波动。这是许多业内人士和专家的观点,他们都肯定,消除波动性是使加密货币成为可行支付手段的关键。因此,有些评论家认为,货币的未来属于稳定币,而不是像BTC这样的波动型加密货币。但业内对此也有不同的观点。首先,随着比特币越来越受欢迎,它的波动性可能会随着时间的推移而降低,从而使它更适合作为一种支付手段。此外,稳定币可能会因为受到监管而几乎消失,而由于与通胀性法定货币挂钩,许多稳定币可能会变得不稳定。(Cryptonews)[2020/7/6]
难办的是,许多状态用过之后就会静静地躺在那里;一旦某个用户停用某个应用之后,就会产生一些“垃圾状态”——不会再派上用场,但会永远存在那里。
理论上,用户可以做到“垃圾不落地”。用户可以仅发布带有SELFDESTRUCT条件的合约,等他们再也用不上这个合约的时候,就调用这个操作码移除这个合约、清空其token余额;他们还可以使用智能合约钱包,通过一个已有的外部持有账户来发送交易,而无需生成一个新的EOA。
观点:矿机行业竞争加剧 比特大陆仍将担当市场领导者:新的比特币矿机生产商正带着新产品进入市场,试图削弱比特大陆和嘉楠耘智等主要矿企的主导地位。随着比特币5月完成减半,矿机生产商正越来越多地推出效率更高的矿机,从而进一步加剧了该行业内部的竞争。像MicroBT等较新的矿机生产公司可能会获得更大的市场份额。
业内专家预测,在可预见的未来,像比特大陆这样的公司仍将引领市场。无论如何,该行业竞争的加剧将有利于矿工,也有利于比特币的价格,因为有了更高效的矿机,矿工出售比特币的压力将减轻。Greenidge Generation首席财务官Tim Rainey表示,虽然比特大陆的市场份额在过去一年有所下降,但其市场规模同期增加了一倍多,目前的算力是2019年6月的两倍多,而且比特大陆仍然保持着全球市场的大部分份额。Rainey同意MicroBT的市场份额似乎是其他制造商中增长最快的。不过,他预计“在可预见的未来,由于蚂蚁矿机在性能、可靠性和售后支持方面的优势,比特大陆将继续成为市场的领导者。”(Cryptonews)[2020/6/14]
但是在实践中,这样的激励非常少,而适当的状态清理的技术复杂性又太大了。在许多合约中,给任何人赋予这样调用SELFDESTRUCT的权限都是不合适的,而且,也会给用户体验和代码上也会增加很多复杂性。实际上,由于SELFDESTRUCT用处极其有限而副作用极大,我更倾向于永远移除这个操作码。如果我们真想控制状态数据的规模,我需要的是一个网络中的节点可以默认丢弃不再被使用的“垃圾状态”的方法。
无状态客户端
这个问题的一类解决方案基于“无状态客户端”的观念。基本原理是,让区块验证不再以持有全局状态为前提。相反,区块会自带证据”),证明其所访问状态的值。就跟现在的设计一样,区块内会包含一个“状态根”,所访问的值可以对应着状态根得到证明。以太坊现在的状态树方案支持这样的证明技术,像二进制树或者VerkleTrie这样更高效的方案也可以。见证数据也会证明处理完该块后新状态根的正确性。
无状态性有两种形式:
弱无状态性:出块者仍然需要完整的状态,以为区块生成见证数据;但验证区块的阶段可以是无状态的;
强无状态性:没有任何节点需要完整的转台。反过来,是交易发送者需要提供见证数据,而出块者可以聚合这些数据。交易发送者自己负责存储为所关切的账户生成见证数据所需的部分状态树。
强无状态性是一个非常“优雅”的解决方案,因为它把责任完全转移给了用户,虽然为了保证实践中的良好用户体验,我们需要创造某些类型的协议来帮助不运行个人节点的用户维护状态、并处理用户需要与意料之外的账户交互的情形。打造这样的协议非常难。
此外,所有类型的无状态性都提高了网络所需的数据带宽;而强无状态性还需要交易声明其所交互的账户及存储项的键。
一个更温和的解决方案:状态过期
更温和的解决方案可以归结为不同形式的“状态过期”方案。必须持续得到访问的状态才能保持“激活状态”;而长期无人问津的状态会变成“失活”。具体用什么机制来更新状态,有很多选择,但一般原则是,除非某个状态对象被显式地更新,否则就以某种形式处于失活状态。因此,任何创建新状态对象的活动,都只能成为节点在一段时间内的负担,而不像现在这样变成永久负担。
失活状态,故名思义,就不是“状态”的一部分;想要处理区块或创建区块的节点无需存储失活状态。不过,失活状态不是被完全删除了!在所有类型的状态过期提案中,都预设了某种方法可以“复活”已经失活的状态。
一般原则是,激活状态的使用与当前相同,而失活状态则需通过上述无状态客户端的机制来使用。复活一个过期状态对象的事务需要提供一个证据,来证明该对象是失活状态的一部分。为了能够生成这样的证据,用户自己需要存储和维护至少一部分失活状态。
何时过期
决定过期条件的设计也有很多种。最常见的几种是:
直接租金:逐块逐块收取“租金”,直接以每个账户的余额来支付;状态对象的余额降到了零,该账户就过期了。
剩余存活时间值:每个状态对象都存储一个”剩余存活时间“值,这个值可以通过支付费用来增加
触达即刷新:每个状态对象都存储一个”剩余存活时间“值,并且每逢读取或写入该账户都会增加该值
所有状态对象定期过期:也就是ReGenesis提案
我自己越来越喜欢”触达即刷新“方案,因为它避免了应用需要创造复杂的经济模型来让用户承担状态租金;以及它保证了激活状态的规模有一个清晰的上限。让大量状态按照规律的时间间隔过期的方案也有同样的好处,但也有一些有趣的权衡:关键好处是,过期方案更简单,但关键不足是,跨过一个过期时点后,你再激活自己的状态对象时,需要多少见证数据会跟你触达状态对象的时间点有关。
账户层面的过期vs.存储槽层面的过期
状态过期的逻辑既可以运营到账户层面,也可以运用到单个存储槽层面。当前,我强烈偏向于在存储槽层面实现状态过期方案。因为很多合约账户的存储槽数量是不受限制的,任意用户都能加入合约并增加合约名下的存储槽的数量。不管使用什么样的账户层过期方案,想要实际限制状态的规模,租金的数量都必须与合约内存储槽的数量成比例。结果是,用户还是能够仅支付一次性的费用就给合约及其用户施加永久的持续性成本。
要解决这个问题,合约要么加入复杂的内部逻辑,将存储操的租金“转嫁”给用户,要么重新设计自己合约的模式,转向使用CREATE2操作码创建新的合约并使用这些合约来充当存储槽。不管是哪种办法,最后都会变成等价于存储槽层面的过期方案。因此,我个人认为,我们应该仅在合约存储槽层面实现状态过期方案。
但是,存储槽层面的过期方案也有自己的缺点:每个存储槽都要增加一个元数据,指明它何时过期,这也意味着“复活冲突问题”不仅会影响账户,也会影响存储槽。
标签:FXSFRAXFRALFDfxs币价格今日行情frax币价格Fragments of arkerSelfdrop Token
1、道兄,每天都在听你的分享,你说现在更看好Defi头部项目,但币种太多了,有没有现在合适入场的项目呀?---我曾经在文章中罗列过这些币:UNI、BAL、COMP、Maker、CRV、Aave、.
Krakenissupportingthelaunchofanewindependentinitiativetoactivelyinvestinearlystagecryptocurrencya.
亲爱的用户:币安创新区将于2021年02月18日17:00上线FraxShare,并开放FXS/BTC、FXS/BUSD交易对,FXS充值通道现已开放。FXS的上币费用为0BNB.
从2020年8月25日Filecoin太空竞赛1截止到现在,已经有5个多月了。我们都知道扇区生命周期是180至540天,而2020年11月24日是个分水岭,在此之前的扇区是不可续期的,因而未来会.
尊敬的社区用户: 由于钱包升级,霍比特交易所现已暂停XTZ的充值和提现。霍比特交易所将在XTZ钱包升级完毕后恢复充提业务,具体时间将以公告另行通知.
NFT现在规模尚小,但增势猛劲。截至今年1月29日的一周,NFT的销售量相当于600?万美元。虽然这只占所有加密资产日成交量的?0.003%,但与前几个月和几年前相比,这已经有显著的上升.