本体技术视点 | 一文读懂Substrate的合约机制(一)_USD:usdc币与usdt币哪个好

本期我们分享来自本体技术团队的一篇文章的第一部分,关于Substrate的合约机制分析。

01

概要

Substrate把整个程序逻辑分为Host和Runtime部分,Host功能是固定的,偏向于底层,是采用原生执行的方式,而Runtime部分是动态的,偏上层业务,编译成Wasm字节码,这样可以随时升级,其执行在Wasm虚拟机中。合约功能作为上层业务,放置在runtime中,由contractpallet模块负责。通过分析本文主要要搞清楚两个问题:

1.合约设计的经济模型:交易执行收费和存储租金机制;

Gate.io针对ORDI提现手续费问题发布补偿方案:5月20日消息,据官方公告,Gate.io将对提现初期遇到手续费问题的ORDI用户进行补偿,手续费高于65 USDT价值的用户可联系客服登记退回差价,并将额外获得65 USDT奖励。[2023/5/20 15:15:56]

2.合约的执行机制:本身跑在Wasm虚拟机里的runtime里是怎么跑用户Wasm合约的。

Runtime的contractpallet扩展了Currencytrait的账户系统,因此可以和其他基于Currency实现账户系统的模块一起使用。扩展的合约账户具有实例化合约和调用其他合约和非合约账户的功能。

Marathon Digital在美国蒙大拿州的矿机受暴风雨影响停机:6月29日消息,比特币矿企Marathon Digital(MARA)表示,由于6月11日暴风雨席卷该地区,其位于美国蒙大拿州哈丁的矿机目前处于停电状态。该公司在蒙大拿州部署了约3万台矿机,占该公司现役矿机总数的75%以上。

Marathon Digital发布声明称,这些矿机可能可能会一直处于离线状态,直到受损的发电设施得以修复。一些采矿设备最早可能会在7月的第一周上线并以降低的容量运行。(CoinDesk)[2022/6/29 1:38:22]

为了合约代码的复用,将合约代码的上传部署和合约账户的实例化分成两部分,多个合约账户可以从同一份上传的code进行实例化。

Tether:USDT稳定性来自赎回设施而非交易价格:金色财经报道,Tether 官方网站发文《USD? – The Blueprint for Private Stablecoins》,文章指出 Tether 的抵押稳定币 USDT 在动荡的市场条件下仍能保持其稳定性,因为 USDT 的稳定性来自其赎回设施(经过验证用户将 USDT以 1:1 的比例兑换美元),而不是其在交易所的交易价格。如果 USDT 价格在主要交易所偏离 1 美元,就像 5 月发生的那样,这并不意味着 USDT 已经失去了挂钩。每当 USDT 在交易所偏离 1 美元时,Tether 都会继续以 1:1 的比例快速将 USDT 兑换成美元,并且对赎回规模没有限制,而这正是 Terra/Luna 失败的原因,这个教训不需要再学习了。[2022/6/16 4:32:50]

02

合约的经济模型

为了避免垃圾交易和恶意合约占用计算和存储资源,合约的设计考虑了交易执行收费和合约存储收费逻辑。当合约账户的余额不够支付存储租金时,合约的存储会被清理并进入tombstone状态。

合约的生命周期

alive状态的合约信息

当合约处于正常工作状态,其主要有以下信息:

tombstone状态的合约信息

当合约进入tombstone状态后,合约的所有存储都会被清理,合约信息里只有一个对storage_root+code_hash进行hash的值。

合约的复活

合约进入tombstone状态后,技术上是可以进行恢复的。首先需要准备一本新临时合约T,往T合约的存储中插入原合约中的key-value对,使storageroot和原合约完全一致,然后调用restore_to合约接口,这个接口会检查当前合约的storageroot是否和要恢复的tombstone一致,如果满足要求那么就使原合约复活,并且将当前的临时合约的资产转移到复活合约,并销毁当前临时合约。

执行合约的Gas收费

交易的sender必须在每个call中指定gaslimit,未使用完的gas会在调用结束后返还。当到达了指定的gaslimit后,那么所有的call和相关的状态变更只会在当前调用的合约层进行回滚,比如,合约A调用B,并且B执行时gas不够,那么所有B的调用将被回滚。如果A能对错误进行正确处理,那么A的其他调用和状态变更依然可以进行持久存储。初看起来这样做是一个极大的限制,但其实是底层增加了灵活性,因为并不是所有的调用都是灾难性的,因此给了调用方可以进行合理的判断和处理的机会;如果想要其他链那种出错就完全回滚的方式,那么可以在调用B出错后A也直接报错回滚A的变更。

对于Wasm的每一个指令和host函数都设置了对应的InstructionWeight。

runtime会准备一个gas(amount:u32)的计费函数,在Wasm合约上传后,立刻会对Wasm中的每一个函数进行计费函数的插入生成新的code。后续合约的执行都以新的code为准。

下一期我们将继续围绕Substrate的合约存储的收租机制、Wasm合约限制、合约对外部交易的接口等方面展开。

如有任何疑问,可通过research@ont.io联络我们。

来源:金色财经

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

水星链

[0:0ms0-0:739ms