译文出自:登链翻译计划
译者:翻译小组
校对:Tiny熊
背景介绍
有时,从区块链获取数据的成本可能会非常高,不管是从请求花费的时间还是从发送的请求数量上来说,都是这样。如果我们想同时获取大量数据,用来在仪表板上显示或进行分析,我们必须调用合约的不同函数或者用不同参数调用相同函数,这些都可能会导致查询时间很长。另外,当我们使用像Infura这样的节点提供商,也很容易达到发送请求数量的限额。
什么是Multicall?
Multicall是一个npm软件包,可将多个HTTP调用分为一个组。用这个方式,之前想从_n_个不同的请求中获取的数据,现在可以在发送HTTP请求之前对它们进行分组,然后进发送一个请求,从而缩短了请求响应时间,并降低了eth_call调用的次数。
用测试了解运作方式
为了了解这种机制的工作原理以及相对于传统方法是否确实有所改进,我们将通过一个对比测试来验证。分别在不使用Multicall和使用Multicall的情况下,对每个函数调用_n_次,然后分析结果。为此,我们通过调用函数getAccountLiquidity来查询Compound协议。我们将使用1,000个不同的地址来获取所有地址的信息。
创建项目
安装依赖
为了进行测试,先创建一个Node项目,并将安装依赖项:ethers
calculatetime.js
调用合约
常规循环调用
先使用传统方法进行测试,我们将遍历1,000个的地址数组(在map循环中),逐个获取每个查询的结果,执行方法如下:
constgetLiquidity=()=>{constcompoundContract=newethers.Contract(compound.comptroller.address,compound.comptroller.abi,provider)returnPromise.all(accounts.map(account=>{letdatatry{data=compoundContract.getAccountLiquidity(account.id。catch(error){console.log(`Errorgettingthedata${error}`。returndata})。
上面实例化compoundcomptroller合约,并在每个地址上调用流动性函数。
使用Multicall调用
使用Multicall调用时,调用函数必须稍作更改,形式如下:
constgetLiquidity=async()=>{constethcallProvider=newProvider(provider);awaitethcallProvider.init();constcompoundContract=newContract(compound.comptroller.address,compound.comptroller.abi,)constcontractCalls=accounts.map(account=>compoundContract.getAccountLiquidity(account.id))constresults=awaitethcallProvider.all(contractCalls);returnresults}
利用Multicall包中的Provider和Contract类。首先,初始化provider,并传递web3、合约地址及其合约ABI。
创建完成后,执行则和之前类似。在map里,调用帐户流动性函数。但是现在它不会发送到网络,而是将它们分组到一个数组中。创建此数组后,将调用创建好的MulticallProvider的all函数,并进行网络调用。
对比分析结果
要查看是否确实有重大改进,只需要对比两个调用消耗的时间。
传统循环方法消耗的时间:
Timetoprocessinmilliseconds:124653Timetoprocessinseconds:124.653Numberofentriesintheresult:1000
使用Multicall调用
Timetoprocessinmilliseconds:9591Timetoprocessinseconds:9.591Numberofentriesintheresult:1000
结论
通过结果对比,发现使用Multicall调用时间的减少是非常可观的,从124秒减少到9.5,花费的时间减少大约十倍。
另外,如果比较eth_callRPC调用的数量,同样是非常明显的减少,从一千个减少到只有一个。
因此,如果我们依赖第三方的节点提供商,而在该提供商中对API的调用是有限额,则这一点也同样重要。
本翻译由CellNetwork赞助支持。
来源:https://medium.com/better-programming/speed-up-your-defi-queries-using-multicall-d4cf652d8ab6
参考资料
登链翻译计划:https://github.com/lbc-team/Pioneer
翻译小组:https://learnblockchain.cn/people/412
Tiny熊:https://learnblockchain.cn/people/15
Infura:https://infura.io/
Multicall:https://github.com/cavanmflynn/ethers-multicall#readme
ethers.js:https://docs.ethers.io/v5/
money-legos:https://money-legos.studydefi.com/#/
CellNetwork:https://www.cellnetwork.io/?utm_souce=learnblockchain
免责声明:作为区块链信息平台,本站所发布文章仅代表作者个人观点,与链闻ChainNews立场无关。文章内的信息、意见等均仅供参考,并非作为或被视为实际投资建议。
本文来源于非小号媒体平台:
登链社区
现已在非小号资讯平台发布105篇作品,
非小号开放平台欢迎币圈作者入驻
入驻指南:
/apply_guide/
本文网址:
/news/9579148.html
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场
上一篇:
币安为何推出第三条链?这对BNB意味着什么?
标签:ALLCALCOMICAtrustwallet什么钱包ethical怎么记忆COMOS价格Mexican Pepe
DeFi跨链势在必行 最近波卡拉的很快,目前市值排名第四,超越瑞波应该不难,主要对标以太坊,也是公链之争,DEFI作为2020年的热门项目,跨链势在必行!跨链项目中,波卡生态项目占了很大比重.
下面老李跟大家分享下1.14日晚间给出的全网公开单和实仓客户的操作情况:1.14日晚间21:12时老李给出BTC38000-38200附近多单目标39200附近的策略.
昨日比特币在突破38000一线压制后,行情小幅调整晚间再度上攻,价格如预期上行至40000区域,高位触及40131位置走出回落,总市值再一次回到1万亿美元以上.
欧洲中央银行总裁克里斯蒂娜·拉加德呼吁对比特币进行全球监管。她说,比特币是一种高度投机的资产,并且“开展了一些有趣的业务”.
市场上充斥着价格不一的“名山名寨古树普洱茶”。有100元的班章,也有1万元的班章;有400多元的冰岛,有4000多元的冰岛……如果卖普洱茶的店铺没有老班章、冰岛、昔归,都不好意思说是卖普洱茶的.
链闻消息,隐私及数据保护平台HOPR宣布推出代币HOPR,总供应量为10亿枚,其中公共发行占比8.50%,质押节点奖励占比25%,项目奖励占比6%,项目基金占比25%,早期投资者占比16.5%.