Oracle原理与问题
区块链的数据来源有两个:一个是链上数据(如地址持有的ETH的数量),,另一个是链下数据(如ETH现在在交易所的价格)。要获取后者,就需要预言机将这个数据告诉给合约。
为什么互联网也需要有“网下”数据,但没有预言机问题呢?因为区块链上的数据需要经过共识,因此预言机上传上来的数据也需要是可信的,而互联网(Web2)上的数据其实本身都是中心化的.
预言机所需要解决的是从数据源到处理到喂价的信任问题,通常不是数据本身的问题.
链下Oracle
预言机的信任问题包含了数据源与数据获取与喂价,针对它们分别有以下解决方案:
a)数据源:可信联盟/去中心化网络
我认为数据源可信是预言机信任问题最重要的一个点,但是这些数据很多都是链下的,链下的数据其实是无法证明是完全可信的,就像你无法证明ETH的价格一定是某个值一样.无论是采用可信联盟还是去中心化预言机网络,都无法生成一个完全没有套利空间或者OEV的价格.
前Blockstream CSO:以太坊向PoS过渡将使监管机构更容易控制网络:8月21日消息,前 Blockstream 首席战略官 Samson Mow 近日在社交媒体上发表对以太坊合并相关看法,他认为以太坊的问题在于其往往优先考虑 Token 经济学,而不是去中心化,因此随着向权益证明(PoS)网络过渡,监管机构将更容易控制网络继而加剧监管捕获(regulatory capture)风险。
Samson Mow 表示,将验证者的最低门槛设置为 32 ETH 会限制验证者的数量,此外,66% 的验证者需要遵守 OFAC 规定,他们存入质押的 ETH 无法提取(因为提取功能未被编码),所以与工作量证明(PoW)共识机制相比,PoS 网络其实更加中心化。[2022/8/21 12:38:47]
唯一能解决数据源可信问题的就是在未来如果流动性和经济活动大部分都聚集在链上,而不是交易所的时候,去完全采用链上预言机(UniswapTWAP),这样可以保证数据源是“Crypto-native”和完全可信可验证的.
b)数据获取与喂价:可信计算
TownCrier使用SGX来保证数据的获取可信;Empiric使用StarkNet上的合约来保证数据的获取和计算可信,且数据源会直接讲价格数据发送到StarkNet上的其他合约中,从而达到第一手数据,保证数据源的可信度;Redstone通过SmartWeave智能合约让任何人都可以成为数据处理者,且使用Arweave存储价格数据从而保证数据可信和可以在事后被验证;Chainlink使用Chainlink网络的链上聚合合约来计算出数据结果,再发送到区块链上.
以太坊联合创始人Anthony Di Iorio:将不再涉足加密货币领域:以太坊联合创始人Anthony Di Iorio表示他将不再涉足加密货币领域,部分原因是出于个人安全考虑。Di Iorio拒绝透露自己的加密货币持有量或净资产。在接下来的几周内,他计划出售专注于去中心化技术的软件开发公司Decentral,并重新专注于慈善事业和其他与加密无关的企业。Di Iorio希望及时与他参与的其他初创公司断绝关系,并且不打算再资助任何区块链项目。据悉,Decentral是数字资产钱包Jaxx的制造商。(彭博社)[2021/7/17 0:58:32]
任何应该上链的应用最终都会被上链,这样才能满足区块链透明化,可验证,无需准入门槛,去中心化的特点.
完全链上化的价格预言机会彻底解决数据源和数据获取与喂价问题,让DeFi应用给所有人带来经济活动上的自由.
TWAP(Time-WeightedAveragePrice)
TWAP是Uniswap所推出的价格预言机.它的数据源完全来自Uniswap协议自身的交易数据,数据的获取和处理也是完全在链上进行,开发者也可以直接在链上使用UniswapTWAP进行代币价格计算.
NEAR将于2023年发布Phase2分片,2024年交付Phase3分片:11月12日消息,NEAR发布2023至2024年协议路线图,未来两年NEAR将发布两个阶段的分片以及部分重要的功能,Phase2计划2023年发布,2024年会交付Phase3分片。路线图中涉及的部分功能包括元交易、零余额账户、Secp256r1秘钥、全局存储、在wasm内运行wasm等。[2022/11/12 12:55:43]
TWAP的原理是基于每个区块的最后一笔tx时的代币价格,结合区块时间,计算出协议整个历史中一个代币的价格总和,从而使用时可以重新计算出一个平均价格.
使用最后一笔tx时的价格,是为了让攻击者的攻击成本不可预测,从而增加预言机安全性.因为就算攻击者在一个区块的最后一笔交易中控制了价格,他也无法预知下一个区块中的相关活动的排序等信息.根据链上分析,这种跨区块的攻击还没有发生过.(剧透一下,PoS好像就不一定,后文会说).
加入时间的变量,是为了进一步增加攻击成本,通过牺牲对即时价格的反映,保持价格的整体稳定性和安全性.
以太坊单日销毁量近一个半月来持续低于3000ETH:8月30日消息,据欧科云链OKLink 多链浏览器数据显示,当前以太坊总销毁量为 260.21万枚 ETH,自7月16日起ETH单日销毁量已持续1个半月低于 3000 ETH,近1小时销毁量前三的协议分别为Uniswap V3 、 OpenSea及Uniswap V2。[2022/8/30 12:57:56]
UniswapV2TWAP
V2TWAP的使用可以是直接拿到一个时间段内的总价变化,除以设定的时间段t,就可以得出一个平均价格,作为代币的价格.每隔一段时间(不一定是t,可以用滑动窗口算法,延迟就更小),则重新获取最新时间段内的价格.
对于TWAP来说,时间参数越长,更新越慢,但安全性越高,因为价格操纵的成本基本上就是时间区间内在每个区块上套利和发送交易的开销.
UniswapV3TWAP
V2TWAP是用时间段内的总价(price*time),V3是时间段内的总tick(tick*time).
华尔街日报:Adam Neumann的加密初创公司推迟发布代币:金色财经报道,WeWork创始人Adam Neumann的加密企业Flowcarbon因市场状况推迟推出其原生代币Goddess Nature Token。Flowcarbon是一家初创公司,它将加密货币与碳信用相结合,以创建可以在所有者想要抵消排放时燃烧的代币。
联合创始人Dana Gibber表示,公司已决定等待市场稳定后再推出产品。该代币原先预计将在6月底推出,但现在已无限期推迟。(theblock)[2022/7/16 2:17:53]
V2中我们提到了要每隔一段时间去重新获取价格,这可能就需要Keeper的参与,UniswapV3解决了这个问题.
V3直接通过一个可定义长度(视需求和网络时间戳行为不同而定)的数组来存储区块时间戳和总tick,当合约产生Swap等交互时,这个数组就会被更新,无需Keeper的主动触发.
除此之外,使用时还需要把tick转换成价格,稍微比V2难用一点.
TWAP的限制
既然TWAP那么好用,那么可信且可验证,完全去中心化,那为什么Chainlink被如此广泛采用呢?
写本文的动机其实就是看到了推特上有人说,EulerFinance从TWAP切换到Chainlink是一种升级(注意此人ID…==).
他称TWAP是非常不安全的,因为PoS之后可以进行多区块的预言机操控,这个其实是可以完全被解决的.
相比之下,我认为TWAP完全去中心化和完全链上操作的优点会比Chainlink好很多,在长期看来,如果没有显著的需求上的差别(比如你要把天气数据搬到链上),那么最好的选择还是TWAP.
TWAP和Chainlink的对比如下:
TWAP被全面碾压,但我个人认为,去中心化和安全性是1,而其他的因素是0,完全链上化是一种趋势.任何人都可以做一条比以太坊快非常多,便宜非常多,支持更多语言的智能合约平台,但却无法杀死以太坊.
PoS后TWAP的风险
ChainLinkGod所说的PoS网络中对TWAP预言机的攻击问题,EulerFinance的工程师自己就知道潜在解决方案,Uniswap的工程师也考虑到了.
PoS后,因为出块者可预测了,所以更容易结合以下方式进行多区块攻击:
大Validator可能被连续分配区块
通过Flashbot来发送Privatetx
Multi-blockbundle
PoW和PoS的不同情况下,针对V3ETH/USDC交易对的30分钟时间窗口(144个区块)的TWAP,要操纵价格造成30%的波动,需要以下成本:
PoW:23.7万亿美元
PoS(连续控制窗口内2个区块情况下):23.7万亿美元
PoS(连续控制窗口内3个区块情况下):95亿美元
PoS(连续控制窗口内5个区块情况下):1.03亿美元
控制越多区块,操纵的成本就显著地越低,那么解决方案是啥呢?
暂时性解决PoS后TWAP的操纵风险的方法是:
选择更大的时间窗口
选择流动性更好的池子.
完全解决PoS后TWAP的操纵风险的方法是:
用Median而不是Average.
这样操纵者就需要控制超过半数的区块,才能操纵价格,对比上面的情况,就需要控制73个区块,这个数字应该大到无法表述了.
未来的预言机
我认为在未来,一个完美的“预言机”需要:
完全来自链上的可验证数据源(那么就是基于TWAP),且支持多链.
通过ZK或完全链上可信计算进行数据获取和处理.
但是这些可能就需要处理以下几个现存或将会出现的小问题:
满足种类,精度,时效性需求的链上数据(当然Chainlink等一样有价格延迟的问题,而且本身就是为了数据安全性而牺牲时效性)
彻底解决TWAP数据源价格操纵(更深的池子,更大的窗口,使用中位数而不是平均数)
整个预言机信任短板的消除(多签?网络去中心化程度?不靠谱的Fisherman机制?)
数据的跨链获取与喂价,多链场景中链上数据的可信传输
数据源多样性(比如只用UniswapV2或者V3不太好)
可信环境下执行的Keeper(如果需要的话)
我相信在未来,越来越多的经济活动会发生在链上,越来越多的价格数据和交易对会存在于DEX上,Uniswap也就可以提供更好的TWAP,也就会有其他方案能基于TWAP实现我设想中的完美预言机,最终达成一个100%去中心化的金融系统.
作者:msfew@ForesightVentures
原文标题:《ForesightVentures:Crypto-Native预言机的基础TWAP》
来源:DeFi之道
来源:金色财经
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。