作者:律动研究院
原标题:《黑暗森林中,不是只有”抢跑“才能获利》
了解以太坊黑暗森林的朋友一定对抢跑(Frontrunning)套利机器人印象深刻。这些机器人程序会时刻监测交易池中待确认交易,当发现存在套利空间的交易时,他们会发起一笔gasprice更高的转账,确保能够在可套利交易前抢先入块。
举一个最简单的抢跑例子,此时1枚UNI可兑换2枚USDC,通过监测我发现交易池中有一笔通过Uniswap以USDC大量兑换UNI的待确认交易,我会发起一笔比此待确认交易gasprice更高的USDC兑换UNI的交易,确保我的交易能够排在此交易之前被确认。由于大多数以太坊矿工挑选交易的默认标准为gasprice的高低,为了自身收益最大化矿工会选择gasprice高的交易优先入块。因此我们就以2USDC/UNI的汇率兑换到了相应的UNI。当那笔大额兑换UNI的交易上链后,假设由于滑点引发的价格变化将USDC-UNI的汇率拉升至了3USDC/UNI,此时若我将之前换得的UNI兑换回USDC就可实现50%的盈利。
然而在神奇的DeFi世界中,不是只有抢先别人一步才能获得套利机会,还有一种套利机制叫做「尾追」。
DeFi风险管理工具Union Finance推出不可交易的治理代币UNION:3月24日消息,基于以太坊的DeFi风险管理工具Union Finance宣布推出治理代币UNION并成立DAO。UNION总量为10亿枚,其中20%分配给社区DAO,46.78%分配给团队,33.22%分配给早期支持者。2%将用于空投给协议的早期用户。UNION为不可转让治理Token,不能被购买或出售。
Union Finance是一个无抵押贷款协议,目前已上线以太坊主网和Arbitrum上运行,曾于2020年12月完成1kx等参投的300万美元融资。[2022/3/24 14:14:54]
bZx「尾追」事件
2020年7月13日,保证金交易借贷协议bZx通过Uniswap进行了其治理代币BZRX的IDO。此次拍卖在以太坊第10451767区块时开始,bZx总共提供了500万枚BZRX代币。
活动刚一开始,某用户就「尾追」其后成为了本次IDO的第一位参与者,并以比发行价略高一点的价格兑换了IDO总量几乎一半的BZRX代币。随着参与者的增多,BZRX币价一路攀升,几分钟后,该用户以发行价10倍的价格将最初兑换的所有BZRX卖出,并成功将近55万刀的盈利收入囊肿。
Avalanche链上DeFi协议总锁仓量为114.5亿美元:金色财经报道,据DefiLlama数据显示,目前Avalanche链上DeFi协议总锁仓量为114.5亿美元,24小时增加1.68%。锁仓资产排名前五分别为AAVE(27.9亿美元)、TraderJoe(16.9亿美元)、Benqi(15.4亿美元)、Curve(10.9亿美元)、multichan(9.84亿美元)。[2022/1/16 8:51:55]
听起来这一切好像都很简单,但其实为了完成这次「尾追」操作,该用户准备了700多个以太坊账户,并对交易池进行了严密的监控。
为了让大家更容易理解什么是「尾追」,我们举一个更加通俗易懂的例子。假设某平台宣布将在双十一当天零点举行1枚ETH换购100枚BTC的活动,本活动为无许可活动,所有用户可以进行参与。平台将在零点时使用官方地址在链上发起一笔交易宣布活动开始,第一个给官方地址转账1ETH的用户成功获得换购机会,并宣告本次活动结束。所有在平台方宣布活动开始前及活动结束后进行转账则被记为无效。
用户们不知道平台方发起的这笔转账会被收入到哪一区块中,用户更无法判断这笔交易将会是这一块中的第几个交易。那么想在活动开始后第一个给平台转账获得这次换购机会就只能单纯靠运气了吗?
Chainlink预言机上线Avalanche主网,推动高级DeFi App开发的快速发展:据官方公告,Chainlink Price Feeds已经上线Avalanche主网,Avalanche平台的开发人员将能无缝流畅获取各资产类别最安全、最优质的价格数据。Chainlink的Price Feeds机制将赋能智能合约开发者在Avalanche的开源平台上自由搭建高级DeFi应用程序,应用场景如价格敏感的衍生品市场、低成本借贷应用、高通量交易策略等。
促成本次集成的是Protofire项目,该项目既是一个领先的开发工作坊,也是一个Avalanche验证节点,同时他们也获得了Chainlink社区激励奖金,在Avalanche主网调试并原生运行Chainlink预言机。[2021/7/21 1:07:47]
不同的获胜对策
要解决这个问题,我们需要复习一下区块中转账排序的机制。首先,矿工会从交易池中挑选出待确认的交易并将其放入自己所搭建的区块内,而大多数情况下,如上文所说,矿工们默认的挑选标准是GasPrice,也就是说,GasPrice最高的转账将会成为该区块中的第一笔转账。当然,矿工也不一定非要按这种标准挑选转账,例如想要作恶的矿工可以将区块填满对自己有利的转账。
慢雾:BSC项目Value DeFi vSwap 模块被黑简析:据慢雾区情报,币安智能链项目 Value DeFi 的 vSwap 模块被黑,慢雾安全团队第一时间介入分析,并将结果以简讯的形式分享,供大家参考:
1. 攻击者首先使用 0.05 枚 WBNB 通过 vSwap 合约兑换出 vBSWAP 代币;
2. 攻击者在兑换的同时也进行闪电贷操作,因此 vSwap 合约会将兑换的 vBSWAP 代币与闪电贷借出的 WBNB 转给攻击者;
3. 而在完成整个兑换流程并更新池子中代币数量前,会根据池子的 tokenWeight0 参数是否为 50 来选择不同的算法来检查池子中的代币数量是否符合预期;
4. 由于 vSwap 合约的 tokenWeight0 参数设置为 70,因此将会采用第二种算法对池子中的代币数量进行检查;
5. 而漏洞的关键点就在于采用第二种算法进行检查时,可以通过特殊构造的数据来使检查通过;
6. 第二种算法是通过调用 formula 合约的 ensureConstantValue 函数并传入池子中缓存的代币数量与实时的代币数量进行检查的;
7. 在通过对此算法进行具体分析调试后我们可以发现,在使用 WBNB 兑换最小单位(即 0.000000000000000001) vBSWAP 时,池子中缓存的 WBNB 值与实时的值之间允许有一个巨大的波动范围,在此范围内此算法检查都将通过;
8. 因此攻击者可以转入 WBNB 进行最小单位的 vBSWAP 代币兑换的同时,将池子中的大量 WBNB 代币通过闪电贷的方式借出,由于算法问题,在不归还闪电贷的情况下仍可以通过 vSwap 的检查;
9. 攻击者只需要在所有的 vSwap 池子中,不断的重复此过程,即可将池子中的流动性盗走完成获利。详情见原文链接。[2021/5/8 21:37:37]
明确这一点后我们可以采取的策略就是平台方官方地址进行监测,并在发现平台方发起转账并上链后迅速向平台方地址发起一笔gasprice极高的1ETH转账,确保我们的转账成为下一块的第一笔转账。
报告:以太坊DeFi市场活跃钱包数量自2月中旬下降近40%:金色财经报道,DappRadar报告显示,以太坊DeFi市场上活跃钱包数量从2月中旬至今下降了近40%,主要DeFi协议(例如Synthetix和Curve)24小时活跃用户数也下降了10%到15%。但在过去30天内,Uniswap的用户增加了22%,1inch的用户增加了35%。[2021/3/8 18:26:20]
然而,除非平台方的转账是上一区块中最后一笔转账才能确保我们有100%的胜算,但这种情况发生的概率是极低的,所以我们需要想出另一种对策。
如果我们同时发起多笔交易,那这样我们的胜算不就大大提高了吗?假设即使所有被记做无效的转账在活动后平台方都将原封退还,但这个策略还存在着一些问题。首先,以太坊账户受到转账序号nonce的限制,每次只能发起一笔转账,上一笔转账未出现结果前是无法进行下一笔转账的。其次,若用户使用100个账号同时发起转账,那么用户需要预先准备100枚ETH,这个成本是很高的。
这时候智能合约就派上用途了,智能合约不存在nonce限制。若我们部署的智能合约赢得活动,那奖品还是属于我们的。此时我们需要做的就是往我们的智能合约中打入1ETH,然后准备好100个有足够支付GasFee的账户。在拍卖开始的时候,100个账户同时调用这个智能合约,智能合约将向平台方发起转账。
但如果平台方没有按时开始拍卖呢?或者网络出现了延时呢?更好的方法是好好利用起交易池中所提供的信息,因为交易池能告诉你这条链上未来将发生的一切。那么我们需要做的就是盯紧交易池中的每笔交易,试着找出项目方地址所发起的交易,并查明此交易的GasPrice,然后通过智能合约发起100笔与该交易GasPrice相同的转账。
为什么要发起与目标交易GasPrice相同的转账呢?还是根据矿工挑选交易入块的逻辑,由于我们发起的交易与平台方发起的交易GasPrice相同,所以我们发起的交易将有极大概率与平台方发起的交易出现在同一区块中,且很可能会将目标交易「包围」。若我们发起的100笔交易中刚好有一笔交易成为了目标交易后的第二笔交易,我们就成功地成为了本次活动的天选之子,以1枚ETH成功换得了100枚BTC。
「天选之子」的操作
让我们再回到bZx事件,看看那个用户是怎么在短短几分钟内撸到了55万刀的。
若想登录Uniswap创建一个币种的交易对,你需要成为流动性提供者,向Uniswap提供该币和ETH各50%的流动性,这也将决定该币的初始价格,也就是IDO发行价。在7月13日世界协调时间02:28:24,以太坊第10451767块,bZx向Uniswap提供了1000枚ETH和500万枚BZRX代币,以0.0002ETH/BZRX的发行价开始了IDO。
该用户的策略是在IDO开始的第一时间以最低汇率用ETH兑换尽可能多的BZRX,坐等其他用户持续推高汇率,在汇率到达高点时将BZRX兑换回ETH盈利离场。由于Uniswap是唯一的兑换通道,且只有ETH-BZRX交易对,在保证能够以最低汇率兑换BZRX的情况下,之后所有买盘都将推高汇率并变成该用户的获利。
首先,该用户准备了732个以太坊地址并预存好GasFee。随后该用户在IDO开始前不到一个小时的时候部署好了智能合约,并在智能合约中准备了650枚ETH用作兑换BZRX。在IDO开始时刻732个以太坊地址同时广播交易。
最终他成功了,该用户发起的732笔交易中刚好有一笔正好排在了bZx注入流动性的交易之后。这笔成功交易之外的所有交易都失败了。
图片来源:<ThefastestdrawontheBlockchain:EthereumBackrunning>
除了该获胜用户外,还有别的用户也尝试使用此策略。在第10451767区块中,一共有266笔交易,其中141笔来自于获胜用户,还有另外两个尝试使用此策略的用户分别发出了59笔和23笔交易,这些用户发起的交易与启动IDO的交易GasPrice一模一样都是60GWei。最终获胜用户靠努力和付出得到了上天的眷顾。
成功以最低汇率兑得大量BZRX只能算完成了任务的一半,「天选之子」需要将这些BZRX在高点全部出货才算是大功告成。
由于Uniswap使用联合曲线计算交易对汇率,当BZRX储备量越来越少时,价格上升斜率将增加。
在IDO开启之后的第14区块时,他开始出货了!
图片来源:<ThefastestdrawontheBlockchain:EthereumBackrunning>
他将最初以650枚ETH兑换的1966111枚BZRX分批在190个区块时间、大约50分钟的时间内完成出货,共获利约55万刀,总共消耗Gas为1.47个ETH。
想成为「天选之子」其实很难
虽然乍一看用1.47个ETH撸到了55万刀的收益十分诱人,但其实这并没有想象中的那么容易。首先,这一切都是建立在你懂代码、会写智能合约的基础上,并且必须确保智能合约不存在问题,否则智能合约中的资产是十分危险的。其次,就算写好了合约,还有其他会写合约的用户与你竞争这个套利机会,你并不一定能够成为那个天选之子。再者,就算你是第一个冲进去的,而且用最低的汇率冲到了很多代币,如果后面没人接盘,那这些代币同样会砸在手里。最后,最关键的是你得先有650个ETH!
参考阅读:
启动IDO的交易
获胜用户智能合约地址
<EthereumisaDarkForest>
<ThefastestdrawontheBlockchain:EthereumBackrunning>
转自:中钞区块链技术研究院作者:李愿10月22日,央行数字货币研究所所长穆长春在“2020金融街论坛年会”上谈及深圳数字人民币试点情况时表示,还是比较顺利的,“公众的热情超出我们当时的预期.
1900/1/1 0:00:00来源:人民网-区块链频道作者:单志广?何亦凡原标题:《正本清源之三:在中国持有和交易“虚拟货币”的法律分析》“虚拟货币”在很多宣传中被定位为“货币”或者“金融投资产品”,但不论每个人如何认知.
1900/1/1 0:00:00据Cryptopotato10月27日报道,Glassnode数据显示,比特币钱包地址的数量创历史新高,达到3100万。随着比特币估值上涨,加密货币散户投资者猛增,处于历史最高水平.
1900/1/1 0:00:00抓住机会,从了解开始。Polkadot是知名公链,具有广泛的知名度和影响力。区哥本身也比较认可波卡的团队、设计理念,一直都有关注波卡.
1900/1/1 0:00:0011月3日,美国人将前往投票站投票,决定是将乔·拜登还是唐纳德·特朗普送进白宫。《华尔街日报》与NBC新闻联合进行的一项新民调显示,在连任竞选活动的最后几天,特朗普在全国选民中的支持率落后10个.
1900/1/1 0:00:00在投资币圈项目的一众参与者中,常有“代投大哥”振臂一呼:或是强调自己了解币圈私募项目优劣,实操经验丰富;或是透露自身持有特殊资质,拥有优质私募项目的额度.
1900/1/1 0:00:00