自以太坊合并完成之后,以太坊社区已经将关注点转移到如何开始扩展区块链以实现更便宜的交易费用、更快的交易和更高的吞吐量,同时保持建立在这个区块链之上的DeFi协议和其他dAPP的安全性。零知识以太坊虚拟机(zkEVM)目前构成了在以太坊社区内开发的最广受好评的扩展技术之一。# M' U2 |" d' t& q( S1 f6 d
本文的重点将研究zkEVM和zkEVM领域中需要注意的一些关键项目。要了解zk-EVM是什么,我们首先需要了解两个关键概念;零知识Rollup(zk-Rollups)和以太坊虚拟机(EVM)
! T( J: ^6 N2 J6 |
什么是ZK-RollupsZK-Rollup是一种在以太坊区块链之上运行的第2层扩展解决方案。ZK-Rollups是链下协议,它在以太坊区块链之外执行交易,然后通过链上Rollup合约将交易批次提交回链上。ZK-rollup处理交易、执行计算并在链下存储数据,同时将资产保存在链上智能合约中。
7 j: \, k8 l5 R- k
本质上,ZK-Rollups处理链下交易以减少在执行交易时对区块空间的需求,然后将结果发送到以太坊区块链。ZK-Rollups本质上称为零知识,因为在交易完成后,它们会作为一个批次发送回以太坊区块链,并证明它们是有效的。这些证明被称为短的非交互式知识论证(SNARK)。zk-SNARK是用于验证数据真实性的方法,而无需透露交易的全部细节。
5 O, a0 {' a8 G# j* I' c
ZK-Rollups架构有两个关键组件:
! v/ I9 _9 Q4 ?' M
链上合约:ZK-Rollups由运行在以太坊网络上的智能合约控制。以太坊区块链作为主合约,存储汇总块和排序,跟踪存款,并存储汇总状态。链上合约还充当验证者,确保ZK-Rollup生成的块。链下虚拟机:链下虚拟机独立于以太坊虚拟机,是ZK-Rollup架构中处理交易的地方。这确保了以太坊主网络上的区块空间减少。现在让我们看看什么是以太坊虚拟机(EVM):! ]5 m1 Q H* ?+ P- e/ o
什么是EVM
以太坊虚拟机(EVM)是一种数据处理引擎,其功能类似于具有大量可执行项目的分布式计算机。它是虚拟机,是以太坊整个运营结构的基础。它被视为以太坊中处理执行和智能合约部署的组件。每个以太坊节点运行一个EVM,在每次交易后更新,以确保以太坊网络的状态在整个系统中是一致的。' \6 o2 j: @6 M( g2 ]4 y- }% y
现在我们已经研究了ZK和EVM的两个关键概念,让我们研究一下zkEVM是什么:
* h3 z* R8 S8 c0 {( t3 i
zkEVM—更深入的研究zkEVM结合了ZK-Rollups和EVM的概念。因此,zkEVM允许开发dAPP,在使用以太坊虚拟机处理交易和执行智能合约的同时最大化隐私。1 j& j6 P1 G) a6 U
zkEVM 的类型关于 zkEVM 的执行有不同的思想流派。然而,以太坊的创造者 Vitalik Buterin 已经普及了 zkEVM 的分类。让我们来看看 Vitalik 提出的这些分类。2 i9 @" Y; l5 Q9 O4 c# B3 m4 p3 q
4 s- q' \6 O0 O/ e3 B% A5 C
' {/ I' g, ~5 Z P2 ^% V& q
4 b3 q& o6 f* t
Type1 zkEVM这些类型的 zkEVM 也被称为完全以太坊等效。这是因为这些 EVM 完全等同于以太坊,除了更容易生成证明之外,不会对区块链进行任何更改。
2 d! ?& {- }: I& M, ?) q& K: O
正方:
这些类型的 zkEVm 与以太坊完美兼容,可以为未来在以太坊网络上的 zk 集成提供基础。5 b A( o8 _0 J, e; n
3 S; {7 I8 I( n! w
反方:
- h: g7 P" D( v5 y$ f: m- Q
以太坊网络最初并不是为了与 zk 兼容而构建的。因此,以太坊网络可能需要大量计算来进行 zk 证明。因此,这些 zkEVM 可能会导致更长的证明时间,并最终导致更长的交易完成时间。
一些构建 Type1 zkEVM 的项目是来自隐私和扩展探索团队的 Applied ZKP 和 Taiko。) H! W( A( u( E4 c5 R
Type2 zkEVMType2 zkEVM 实现寻求与以太坊虚拟机(EVM)完全相同,但与以太坊等效略有不同。Type2 zkEVM 类似于以太坊区块链,除了数据结构和状态树不同。
: T; P4 N7 Z7 l! k
正方:; R/ V6 j# O8 o3 b* u0 n' @+ J
Type2 zkEVM 具有几乎等同于 EVM 的虚拟机,并将确保与多个 EVM 调试工具和开发人员基础设施的兼容性。
反方: v& t S* b) m4 j7 B# d' ~+ |
6 }( M L: k& n1 a8 A6 w- m# W
Type2 zkEVM 与 Type1 EVM 一样,具有较慢的证明时间,因为以太坊区块链最初不是为了与 zk 兼容而构建的。但是,Type2 zkEVM 的时间稍快一些。: a; H. J) ~% x" Y# ?4 j; @5 p( H
一些构建 Type2 zkEVM 的项目包括 Scroll 和 Polygon Hermez。) w5 W. e! D) l, E
Type2.5 zkEVMType2.5 zkEVM 之所以如此命名,是因为它们与 Type2 zkEVM 非常相似,只是它们改变了 gas 成本。因此,Type2.5 zkEVM 有时被称为修改稿 gas 成本的 EVM 等效。
正方:
由于 gas 成本降低,Type 2.5 zkEVM 相当便宜。
反方:
. _, D) C& S0 |# L# V( H
由于链上的 gas 成本发生了变化,因此存在与集成 Type2.5 zkEVM 的软件创建者可用的开发工具不兼容的风险,并且这种实施可能会破坏一些已构建的去中心化应用程序。
Type3 zkEVMType3 zkEVM 与其他形式的不同之处在于,协议中可以调用操作的次数有硬性限制。因此,这些类型的 zkEVM 有时被称为几乎 EVM 等效。
正方:
Type3 zk-EVM 更容易构建,并且大大缩短了验证时间,因为它们通常消除了难以实现的功能。9 \8 \, e% r5 [! T7 W+ O
3 x9 S8 c) P' H* i. E( u' C; @
反方:
2 [4 z6 t7 G$ z C9 k
大多数协议目前避免保留为 Type3 zkEVM,直到它们能够完全实现使其成为 Type2.5 zkEVM 的特性。因此,由于大多数应用程序需要重写,因此存在更高不兼容性的风险。9 X& H% b" b0 i$ t& D4 W7 k
在它们的早期形式中,Scroll 和 Polygon 被认为是 Type3 zkEVM。
' S0 v) i' r8 b# }9 M
Type4 zkEVMType4 zkEVM 的实现是通过使用以 Solidity 和 Vyper 等高级语言编写的智能合约代码并将代码编译为 zk-SNARK 友好的。因此,它们被称为高级语言等效 zkEVM。- u0 l, H5 f+ @/ t: M
正方:# q Q8 k, A/ ^8 y0 x6 O
Type4 zkEVM 具有非常快的证明时间。
: T5 L Q/ Q: |# _* b
反方:
( }& C) z6 f' J, |$ ]$ P/ q5 k
在使用 solidity 或 vyper 等高级语言编译智能合约时,存在非常高的不兼容风险。* q+ f$ b8 x! F$ }" r2 P
- c. W# O C' H- h+ {
zkSync 和来自 Nethermind 的 Warp 是构建和实施 Type4 zkEVM 系统的项目。
最后自以太坊合并完成以来,我们看到了扩展解决方案的增加,以确保以太坊仍然是执行去中心化金融项目和其他去中心化应用程序的首选层。因此,我们认为这个话题对于 web3 的成功至关重要。但是,同样重要的是要注意,其中一些解决方案是实验性的,并且这个空间正在迅速发展,因此我们恳请您在做出任何投资决定之前密切关注该空间。
" x8 o8 ~' ?& w- P: _, @" J* w( \1 W