感谢AlexGluchowski以及BarryWhitehat提供的意见和看法。1
长话短说
本文介绍了一种无需来自运营方tx历史数据的zkRollup,这具有在L1上使用txcalldata的gas效率,并且还具有智能合约执行及资产隐私的特性。每个batch只需要在txcalldata中记录一个状态改变的所有者的账户列表。缺点是每个用户在将资金退出到L1时,需进行客户端zkp计算,而另一个缺点是在EVM兼容性方面带来困难。2
背景和动机
对于Rollup的运营商和交易者而言,他们在使用txcalldata时仍然会产生消耗。这种限制仅仅是因为需要恢复作为交易结果的状态,以免用户无法生成其资金的Merkle证明。Rollup的大部分规范要求运营商将所有交易历史数据转储到L1上的txcalldata。交易历史数据的这种透明度,不仅增加了txcalldata的gas成本,而且还破坏了交易的隐私。据推测,交易历史数据的累加器,既解决了效率问题,也解决了隐私问题。3
Web3初创公司Junggl Media完成新一轮融资:金色财经报道,Web3初创公司Junggl Media完成新一轮融资,Northbrook Capital Start-up Fund投资,具体融资金额暂未公布,新资金将用于继续扩展其在数字金融媒体、加密Web3和AI方面的产品,为媒体公司提供更全面的创新解决方案。[2023/3/30 13:34:17]
方法
简而言之,在第一步中,我们构造了一个zkRollup,其中运营商将最终状态差异直接写入txcalldata。交易历史数据将在一个zkp电路的隐私输入中。第二步,我们通过分离常用存储和用户状态存储从txcalldata中删除最终状态差异。这使用户可以使用非包含证明退出。用户保留其用户存储并仅公开其Merkle根。用户可以用zkp证明根转换,并且可以更新智能合约的常用存储。详细步骤如下:3.1)第一步,zkRollup中txcalldata使用选项
?英媒:Meta正在筹划新一轮裁员:2月12日消息,Facebook母公司Meta推迟了多个团队的预算案,因为该公司正在准备新一轮裁员。两名熟悉情况的Meta员工称,最近几周,该公司对于预算和未来的员工数一直不明朗。对此,Meta没有立即置评。(《金融时报》)[2023/2/12 12:01:44]
使用txcalldata恢复完整状态有两种选择。选项1:将所有交易历史数据记录到txcalldata。选项2:记录由于区块中的交易而导致的最终状态的差异。在选项2中,由于txcalldata中没有要记录的内容,数以百万计具有相同结果的交易使用0gas进行txcalldata使用。Merkle根转换的可靠性由zkp保证。而采用“选项2”是第一步。3.2)第二步,优化“选项2”
加密衍生品交易所CBOEX正在寻求新一轮2000万美元融资:据官方消息,新加坡加密衍生品交易所CBOEX正在寻求新一轮融资,计划以1~2亿美元的估值融资2000万美元,融资将用于扩展业务及技术人员扩充,同时扩展交易市场,包括东亚、东南亚和东欧等地区。
CBOEX交易所于 2021 年3月正式运营,交易量已达到近3亿美金。[2021/7/12 0:44:46]
当批次/区块中的交易更改合约中的相同存储值时,上述选项2会花费更少的gas。这种共享和更改的值就像ERC20的总供应量、swap协议的总资产池量等。而且这种存储值也会影响到所有资产持有者,这种数据的丢失会导致zkRollup的活性损失。另一方面,其他不常共享和更改的数据大多是个人资产数据。这类数据的丢失,直接意味着资产持有者损失了资金。这种风险是分开的,不会影响到对方的资金。然后分离用户的状态,并提供其状态的用户数据及其证明作为运营商对其交易的收据,从而降低了大量gas成本。交易者向运营方发送交易;运营商将其用户状态的merle证明作为交易的收据;交易者签署这个收据;电路中只接收带有签名收据的交易数据;如果一个用户进行了交易,并且多个用户的余额发生了变化,并且他们知道自己的状态,包括这些余额和Merkle证明,那么他们中的任何一个都可以随时通过zkp退出其资金。这证明这是其余额的最后一个状态,可以通过每个批次的更改状态所有者的每个帐户列表的不包含证明来确定。更改状态所有者的帐户列表的稀疏Merkle树可用于有效证明。有两种方法可以让更改状态的所有者知道他们最近的更改。如果他们在线,运营商发送最后一个差异,接收签名的差异,并将其放入zkp电路的输入,这样的gas成本是最低的。如果他们不在线,运营商会将其发布到txcalldata或链下去中心化存储。通过这种状态分离,运营商不再需要将最终状态的任何差异都放在txcalldata中,因为用户的帐户状态对于退出来说足够安全,而丢失共同共享的数据,只是意味着运营商无法更新zkRollup的Merkle根,他们将简单地停止服务。然后,公共共享存储和用户存储都可以在链外分发。每批只需要在txcalldata中记录一个状态改变的所有者的账户列表。3.3)第三步,隐私智能合约执行
Santiment:DeFi领域很可能开始新一轮上升:10月3日消息,在经历两个多月的狂热后,DeFi行业进入相对平稳的阶段。Cryptoslate独家数据显示,过去一周DeFi代币市值缩水大约11%。但分析平台Santiment最新文章指出,DeFi领域很可能出现新一轮增长。以DEX独角兽Uniswap为例,其交易量有明显下降趋势表明市场上的交易所数量在增加,人们对加密交易的兴趣在提高,一旦Uniswap交易量跌破某点,DeFi市场将可能出现新一轮上涨。(CryptoSlate)[2020/10/4]
用户的交易不在链上,但运营商仍然可以看到并需要看到用户状态,以进行zkp证明。如果用户在其一边进行zkp以证明其用户状态的Merkle根和公共共享存储的转换,则运营商只需更改该Merkle根和存储,余额的秘密仍然存在。用户向运营商发送交易;运营商返回余额和更新后的公共共享存储的差异;用户对更新后的用户状态和公共共享存储的Merkle根进行zkp证明;制作每个批次的运营商可通过更改批次中共享存储的变化知道余额差异,但其无法知道其他批次的余额差异,因为运营商之间只共享最终差异。这具有混合级别的隐私。这种机制需要用到递归zk。4
Fortune:a16z对加密货币和区块链投资明显放缓:10月21日消息,据《财富》(Fortune)杂志披露,a16z参与的全球加密货币和区块链风险投资交易出现明显放缓的迹象。数据显示,管理着76亿美元资金的a16z Crypto在三季度仅有7笔加密和区块链风险投资交易,创下自2021年一季度以来的最低记录。另据据PitchBook的数据显示,a16z Crypto的投资规模也出现骤降从2022年一季度的24亿美元跌至三季度的约6亿美元,但仍高于2021年三季度。
对于《财富》披露的数据,a16z一位发言人表示,鉴于尚有投资交易尚未公开披露,因此该公司对相关数据无法给予确认。[2022/10/21 16:34:34]
更详细的讨论
4、1在链下与离线状态改变者通信
这只是一种选择。该协议可以在没有这部分的情况下构建。即使在最坏的情况下,状态更改器处于离线状态,这种情况下的数据可用性风险也非常有限。离线用户可以在其在线时获取数据以安全退出,其可以设置代理而不是自己接收数据。并且我们可以构造退出方法,以便上次状态更新不会因为数据可用性问题而使之前的状态变得危险。典型的去中心化存储结构如下所示:提交哈希证明preimage(hash(storage))=preimage(hash(storage,last-Ethereum-block-header))-last-Ethereum-block-header继续观察有多少节点可以完成4.2账户链上gas费用
每个帐户都可以获得一个比地址本身短得多的ID。每个batch只需要一个账户列表,这样就可以省略重复项,这比txcalldata中使用的交易历史要高效得多。4.3公共共享存储的进一步优化
在以太坊L1上,你无法擦除txcalldata。我们可以修改它,因为公共共享存储不需要在链上。与交易历史数据不同,我们只需要最后的状态数据,不需要任何之前的状态。然后运营商可以放弃之前在网络中共享的“最终状态数据”。运营商可以通过zkp逻辑知道可以丢弃的数据。5
结论
分离用户状态使得zkRollup智能合约执行既高效又隐私,几乎所有的txcalldata成本都从zkRollup中移除了。本文来自元宇宙之道,星球日报经授权转载。
作者:AmyLiu周二,美国参议院银行委员会举行了听证会,会上讨论了CBDC和金融隐私问题。 美联储主席鲍威尔称美国中央银行数字货币(CBDC)的开发是“关键工作”,他对参议员PatToomey.
随着大力支持GameFi、元宇宙发展,加上欧易NFT一站式交易平台的重磅上线,使整个OEC生态在NFT一级市场认购,二级市场交易及个人NFT创建中形成完整的交易闭环.
文章来源:JustinMart、ConnorDempsey&Coinbase文章翻译:Blockunicorn 来自CoinbaseVentures的“AroundtheBlock”揭示.
吴说作者|火小律内容独家授权吴说编辑转载9月24日下午,央行等十部门全网连发《关于进一步防范和处置虚拟货币交易炒作风险的通知》,传递出5大信号.
撰文:AnthonySassano,EthHub联合创始人编辑:南风以太坊正以多种方式进行扩展。以太坊就像一座经济活动繁忙的超级城市,它全天候运行,跨越全球,允许任何人访问.
用全新的眼光追踪供需 链上分析的一个令人兴奋的地方是,能看到支配比特币市场的潜在供需结构的力量.