观点:原始无序 MEV 时代到来_RON:USDT

设想一种情形:用户在AMM类型的DEX上做交易,无论设置什么滑点,最终都会在你能接受的最差价格上成交。这可能是个对用户来说很可怕的场景。

TLDR;

目前的MEV-Geth实现机制改变了原本网络中预期的交易排序规则,导致诸多细思极恐的公开公正性问题,并且可能已经对生态中的用户产生利益损害。

以太坊网络交易池原生规则

当前以太坊网络中,如果用户通过原生的方式发送交易,这笔交易会在整个由以太坊全节点组成的点对点网络传播,并且交易的内容完全透明,这意味着任何网络中任一全节点能看到绝大部分交易的交易内容。

由此,以太坊网络中会出现几种破坏交易发送者预期和体验的情况,

抢跑,指通过让特定交易在同个区块中排在目标交易前而获利,主要针对清算和套利交易;

尾随,指通过让特定交易在同个区块中排在目标交易后而获利,典型的针对对象是信息输入机制交易或大单交易;

三明治夹击,上述两种攻击形式的结合,让目标交易恰好夹在两笔特定构造交易中间,从而获利。三明治攻击大大拓宽了可攻击的范围,哪怕是一笔普通的AMMDEX交易,都有可能成为针对对象。攻击者的第一笔构造交易制造更大的交易价格波动,待目标交易执行完之后紧接着执行第二笔构造交易,换回发动攻击的代币完成获益。

发起攻击的对象是不确定的。理论上,所有知道了你的交易内容的人都有可能攻击你,dApp项目方、专业攻击者、钱包、矿池,都有可能攻击你。

观点:不应该严格区分Web3和Web2以及dApps和Apps的概念:金色财经报道,Finsia基金会首席执行官Kim Woo-seok表示,为了走出区块链市场的低谷,他认为不应该严格区分Web3和Web2以及dApps和Apps的概念。如果我们坚持只针对dApps的服务模式,区块链市场将无法进一步扩大,区块链应该定位为支持企业的技术,而不应该区分dApps和Apps。为了吸引更多用户,他认为普通用户熟悉的应用程序需要区块链,而不是dApp。如果冷眼旁观,早期的区块链模式大多以失败告终,从服务的角度来看,dApp仍然困难重重,需要改变。[2023/9/5 13:18:28]

攻击的难易程度,与网络的共识规则和生态中普遍可用的基础设施有关;例如,如果大家完全遵守当前的交易池规则,仅通过GasPrice竞争来影响出块者对交易的排序,则三明治攻击是比较难发动。

目前,由于能够直接决定自己所打包区块中的交易的执行顺序,矿工-矿池一直被当成是最有可能发动攻击的参与者,这也是“MEV”这个概念的由来;但实际由于攻击机会具备一定时效性,可能转瞬即逝,攻击者和矿池更多表现为一种分成合作的关系。

这些背景,正是使我对MEV-Geth和其他形式的、矿池直接从事三明治攻击的现象感到不安的原因。

当前的MEV-Geth实现

观点:目前Aptos TPS低于比特币,超80% APT供应由团队和投资者控制:10月18日消息,推特用户ParadigmEng420发文表示,Aptos主网启动,但目前Aptos TPS低于比特币,Aptos在其最终版本中承诺100,000 TPS,但当前的TPS大约是每秒4笔交易,而且这些交易中的大多数不是实际交易,它们只是验证者通信和设置块检查点并将元数据写入区块链。

很难看出用户现在如何使用Aptos,其个人找不到任何RPC,也找不到任何验证器来发送交易。Aptos的总供应量为1,000,739,234.25,但目前已抵押821,111,362.91。这意味着超过80%的APT Token供应由团队和投资者控制,剩余约2亿流动性Token或将坐等抛售。[2022/10/18 17:30:24]

目前MEV-Geth实现的功能仅为,搜索网络中MEV机会的搜索器,转发原子交易包到注册矿池节点,出块节点允许插队。构建出仅在注册矿池和Relay服务器间的简单网络。

MEV-Geth是一种特殊定制的以太坊节点客户端,运行在矿池方,允许通过该客户端存储Relay分发的MEVBundle,并将这些特殊的交易打包到区块中的队列头部位置。

使用者可使用MEV-Geth广播称为Bundle的交易包;一个Bundle内包含的信息有:一个交易列表,套利计算区块高度,最小最大超时时间。在单个Bundle上链的区块中,发送者会通过coinbase交易,向出块者支付ETH作为分佣。

观点:攻击者地址12亿枚aUSD尚未转移,Acala或通过公投进行回滚:8月14日消息,Cryptolingo DAO 创始人、推特用户 @IamJulianaC 在社交媒体上发文表示,Acala 使用 Honzon Fungibility Pallet 使 aUSD 在 Acala 和 Karura 之间进行流通。Honzon 协议的创建是为了让 aUSD 作为原生 Stablecoin 和流动性来源,跨越 Polkadot 和 Kusama 多链生态系统。

由于该协议出现漏洞,攻击者地址(26JmEcghNmggvT46sojckg34Py9zFRKkCcFy3gr49hrFgT2k)能够转移超 10 亿枚 aUSD。

据猜测,Acala 已经阻止该钱包转移资产。攻击者地址中的 12 亿枚 aUSD 尚未离开 Acala 链,且 Acala 很有可能通过公投进行回滚。Acala 团队尚未证实 iBTC/aUSD 池和 Honzon 协议漏洞之间的关系。[2022/8/14 12:24:28]

在当前的MEV-Geth实现中,每一个区块只能存在一笔Bundle,因此出块者会会选出coinbase支付最大的一笔Bundle上链。

这个当前的实现简化了实施三明治夹击的难度。一方面,攻击者可以显式地声明夹击交易的前后关联;其次,夹击者没有了后顾之忧,即使在与其他夹击者的上链竞争中落败,其交易也只会在MEV-Relay网络中超时无效,不需要付出Gas费用。

观点:幸存者偏差导致加密生态系统失衡:10月9日消息,幸存者偏差指的是当取得资讯的渠道,仅来自于幸存者时,此资讯可能会与实际情况存在偏差,未幸存者已无法发声。 人们只看到经过某种筛选而产生的结果,而没有意识到筛选的过程,因此忽略了被筛选掉的关键信息 。在2016-2017年的加密初创公司时代,许多公司推出了承诺以区块链为动力的产品,包括区块链社交网络、通讯、物流、法律技术、电子商务技术等,大多数这些项目失败的原因很普遍,包括产品市场不匹配或缺乏对产品的网络效应驱动。而早期区块链产品时代的赢家大多是金融产品,这导致加密货币中的金融产品占主导地位。区块链对金融经济的关注过多,以至于从某种意义上说,加密基本上已经放弃了实体经济。从产品的角度来说,关注整个行业的发展是极其重要的。加密货币必须发展成为一个高效的市场,人们可以轻松地使用加密货币购买服务和产品;也就是说,需将其用作各种易于使用和直观的产品和服务的支付媒介,而不仅仅是用于金融投机。(Cointelegraph)[2021/10/9 20:16:47]

根据Flashbots团队的公开声明,他们正在开发允许同一个区块包含多笔Bundle的方案,或许我们很快会看到区块中充满大量零Gas费的三明治夹击。

找到MEV-Geth交易

根据目前的实现,MEV-Geth交易最显著的特点就是前后两笔夹击交易的GasPrice都为0。

打开区块浏览器网站etherchain.org,查看任一区块的交易列表,如果在列表开头出现了三明治夹击,且夹击交易的GasPrice为0,则这很有可能是通过MEV-Geth发起的Bundle。

观点:无论BTC变得多么糟糕,仍有0.1%的机会成为世界储备货币:ConsenSys产品工程师Bernhard Mueller发推称,无论BTC变得多么糟糕,它仍有0.1%的机会颠覆央行,成为世界储备货币。因此可以投资BTC。[2020/7/5]

-12200018高度区块的列表头部-

-某笔被夹击交易全过程-

网络已全面部署MEV-Geth

当前MEV的情况可以通过对0gasprice并且gasused大于21000交易查询获得,具体见我临时建立的?dunedashboard

从图中可看到,不少矿池都已参与,每天有约超过3500笔MEV相关交易,大约一千多次MEV交易产生。按照平均出块时间在12s来算,每天有7200(60x60x24/12)个区块,即每天有近1/3的区块中存在MEV-Geth交易。还有部分矿池未使用MEV-Geth,套利者还未切换到这种新的竞争模式。

不同环境下的博弈

我们可以借助比较几种交易池运作情形,来了解用户得到了什么,又失去了什么。

公开博弈状态

如果网络回归到原生状态,而且出块者恪守行业自律,所有交易全公开,任何人都能通过建立节点或者通过节点服务发现未被打包的交易;那么,如果想夹击某笔交易,就需要发送两笔交易,并设置gasprice为被攻击交易前后来保证夹击顺序,并且在有竞争的情况下还要发送多份拷贝交易提高成功率,最后在任意交易执行失败时要面临花出矿工费的惩罚。

从用户方来看,大家都处于平等公开的环境下,当看到自己交易被夹击或抢跑时,是有机会有方法加速或取消这笔交易来避免潜在损失的。

而且,最终成型的区块,不仅能显示出交易池竞争的胜者,还能真实地反映交易池竞争的实际情形。

隐私交易服务

此处的“隐私交易”指的是矿池开设专门的通道,由该通道进入矿池交易池的交易不对外广播,但仍根据GasPrice高价优先的形式排序并打包交易。

普通用户使用隐私交易服务时,其交易对外不公开,因此,除非矿池自身违反保密承诺或参与攻击,否则用户不会受到上述攻击。

再从另外一头考虑,如果攻击者通过隐私交易服务攻击公网可见交易,被攻击者无法发现事情即将发生,无法做出应对。但是,三明治夹击仍然受限于交易路由和交易池排序的随机性,无法轻易实施。

而且,当多人竞争同一个获利机会时,只要矿池不透露相互竞争的交易,他们便无法了解竞争对手出价,只能盲出价格进入排序队列,这变相提高攻击成本和难度。

此外,最终成型的区块,仍然能真实地反映出交易池竞争的全部情形,外部可以观测到成功失败及其原因。

若MEV-Geth成为主流

MEV-Geth出现后,套利者抢跑者会将可套利可夹击的交易提交到这个网络中竞价,筛选出上交矿池利益最大的Bundle会放到下一个打包的区块中优先执行,保证被打包交易能达到100%成功率。

在当前,如果你也部署了一个MEV-Geth节点,Bundle内容对你来说是透明的,因此如果有人攻击你,你也能及时响应。

但如果你并不知道什么是MEV-Geth,你的情形与有人动用隐私交易攻击你相同;变得更差的是,攻击者的确定性提升不少,并且攻击过程的竞价也无法得知,因为成型的区块将只暴露那笔胜出的交易,而不会暴露竞争的过程。

Flashbots认为,这会给网络带来一些好处:套利者竞争博弈的过程被移到另外一个网络,可以缓解以太坊P2P网络的负担;只有胜出者占据区块空间,可以缓解区块拥堵。在subreddit/EtherMining上有发布报告列出目前区块中的额外获利情况,但或许长期不一定能赶上矿工费下降带来的总收入减少,需要更多长期数据跟踪研究。

去中心愿景

原本网络共识预期是,以太坊Defi用户和抢跑者处于同一规则下,并且竞争的过程和结果也是透明地暴露在区块中。随着矿池的介入,事情变得更加复杂,隐私交易和MEV-Geth,都让网络底层开始明确介入上层业务。而MEV-Geth似乎用各种好处正当化了对用户的三明治夹击,并且让竞价过程在一个外部无法观测的网络中发生,网络运行过程变得变得不友好也不透明。

我这里有几个问题,

矿池为提供算力的矿工获得利益出发,部署目前这个阶段的MEV-Geth去获取更多利益,这可能无可厚非。但这是否符合去中心和网络的公开公正呢?

Flashbots之前公开承诺里有提到保护以太坊的开放性去中心化,目前MEV-Geth隐私性和公开拍卖竞争问题未解决之前,部署到当前的网络中是否是合适的时机呢?

矿池的排序权引申出来的超级能力,可能在去中心化网络中无法被去除,也就是MEV是个客观存在的事物。但对于MEV-Geth出现让MEV的滥用变得更加便利,甚至成为正当借口去夹击用户交易,这是否造成长期不良影响?

社区中也是有不少关于MEV或MEV-Geth实现的争议,不少声音是担心

康奈尔教授AriJuels在CoinDesk上发表的《Miners,Front-Running-as-a-ServiceIsTheft》

OffchainLab联合创始人EdFelten发表的《MEVauctionsconsideredharmful》,这篇不是针对这个议题,反对的是拍卖一天排序权的这种方法。

Vitalik有一篇对此的回应

EthererumResearch论坛上网友pmcgoohan发表的《MEVAuctionsWillKillEthereum》

Paramdigm基金合伙人CharlieNoyes发表的《MEVandMe》中也提到“MEVCanHarmUsers,MEVCanHarmEthereum”

如果以太坊想成为支撑整个世界的金融基础平台,那么维持用户资产安全以及交易排序的公平性就非常重要。所有参与方都是按照矿工费竞价规则竞争打包队列位置,执行失败会失去支付的矿工费。矿池在打包过程中完全忽略交易内容,仅以矿工费高低来为交易排序,网络验证人和应用参与方隔离开来,互不干涉影响。

MEV-Geth的全面部署以及矿工对以太坊网络的应用层逐步侵入,让我感觉到有些不对劲,周末两天思考和查阅材料,最后写下了这篇内容,希望能让更多人来思考这个可能会对以太坊影响深远的问题,也感谢这几天帮助校对内容的朋友们,特别感谢阿剑老师不断对阐述逻辑和顺序向我发问让文章内容更加完善与逻辑完备。

Flashbots相关内容索引

flashbots/mev-research:ProjectmanagementforMEVResearch

flashbots/pm:EverythingthereistoknowaboutFlashbots

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

金宝趣谈

[0:15ms0-7:834ms