zkVM:比zkEVM更普适的通用扩容方案_ISC:KISC

本文将对比 zkEVM 和 zkVM 在技术上的差异,并介绍 RISC Zero zkVM 及其即将推出的 Bonsai 网络。关于 RISC Zero,它是一个通用 zkVM,RISC Zero zkVM 是一台可验证的计算机,其工作方式类似于真正的嵌入式 RISC-V 微处理器,使程序员能够像编写任何其他代码一样编写 ZK 证明。支持 Rust 和 C++ 编写 ZK 证明,并支持任何编译为 RISC-V 的语言。

随着当前智能合约的复杂性增加,dapp 越来越先进,区块空间越来越稀缺,运行链上代码的成本也在增加。换句话说,如果你的 DeFi 逻辑变得计算昂贵,或者你的链上游戏逻辑需要额外的计算能力,你应该考虑使用 zkVM 或 zkEVM,将复杂的应用逻辑移到链外。

在这篇博文中,我想解释在这种情况下,一个字母所能带来的不同。我将从 EVM 的概述开始,然后是 zkEVM,再接着是 zkVM。zkEVM 允许你在链外传输 Solidity 应用程序,而 RISC Zero 的 zkVM 和即将推出的 Bonsai 网络允许你使用 Rust 编写可扩展的、与链无关的代码。

Opside已在测试网上线ZK-Rollup LaunchBase:8月14日消息,去中心化ZK-RaaS平台Opside已在测试网上线ZK-Rollup LaunchBase,支持开发者构建专用应用程序Rollup,包括Layer1、zkEVM、Gas、Data Availability与Sequencer各个组件。LaunchBase现允许开发者从Opside、Goerli、Mumbai与BNB测试网等EVM兼容的Layer1中选择以构建其应用程序的特定rollup,支持Polygon zkEVM、zkSync、Scroll与Starknet四个zkEVM。[2023/8/14 16:24:39]

快速了解 EVM:

EVM 是 Ethereum Virtual Machine(以太坊虚拟机)的缩写,你可以把它看作是执行 Ethereum 上所有交易的软件。

zkRouter测试网上线首个DApp,支持以太坊和Fantom间资产桥接:5月10日消息,Multichain 推出的跨链基础设施 zkRouter 宣布首个构建在其测试网上的 DApp 上线,即跨链桥,支持从以太坊 Goerli 测试网到 Fantom 的桥接。zkRouter 称,目前开发仍处于早期阶段,用户提供的有价值反馈会得到奖励。[2023/5/10 14:54:31]

每个节点通过运行这个软件(如 geth 等实现)来参与以太坊网络。在以太坊中,交易是由代码表示的,其格式称为 EVM 字节码,代表 EVM 的指令。大体上,这些指令面向数学计算,来获取区块链信息,以及交换金钱。世界上有许多虚拟机,每一个都有自己的专长。以太坊的虚拟机很关键,因为它更适合应用于去中心化的金融(DeFi)。

最近最酷的趋势之一是把 「zk 」放在单词的前面,这两个字母代表零知识证明。维基百科上有很多例子(我最喜欢的是 「两个球和色盲的朋友 」问题)。如果你对它们不熟悉,我建议此时花几分钟时间读一读零知识证明的例子。

V神:ZK-EVM是以太坊Layer 1安全和验证过程的重要组成部分:金色财经报道,以太坊联合创始人“V神”Vitalik Buterin在其官方博客上发布文章《以太坊的多客户端理念将如何与ZK-EVM交互?》(How will Ethereum's multi-client philosophy interact with ZK-EVMs?),其中指出ZK-EVM将在未来发展成为以太坊Layer 1安全和验证过程的重要组成部分,但关键在于如何为零知识证明以太坊区块的正确性创建一个“多客户端”生态系统。V神建议采取开放的多个ZK-EVM,因为不同的客户端有不同的ZK-EVM实现,每个客户端可以在接受一个区块为有效之前等待与自己兼容的证明。此外,Vitalik Buterin还对人工智能最近的快速发展大加赞扬,他觉得人工智能的进步可以“加速”证明ZK-EVM实现的发展。“从长远来看,当然任何事情都有可能发生。也许AI会加强形式验证,使其可以轻松证明ZK-EVM实现等效并识别导致彼此之间差异的所有错误。”[2023/4/2 13:40:23]

长话短说,零知识证明能够实现可验证的计算。你可以把它看作是一种确保哪些计算被完成,以及计算结果是正确的方法。计算机就计算结果达成一致的一种方式是让每台机器运行相同的代码并比较结果。根据不同的计算,这对资源有限的系统来说可能很昂贵。通过使用像 RISC Zero 这样的零知识证明框架,机器可以通过检查证明的数学有效性来确保计算的正确执行,而不是重复运行相同的代码(如 EVM)。

Polygon zkEVM主网Beta版将于3月27日发布:金色财经报道,Polygon zkEVM主网Beta版将于3月27日发布,Polygon并没有具体说明测试版网络将包含哪些内容,但表示团队将在未来几周内发布更多细节。

去年10月,Polygon上线了其zkEVM测试网,该测试网为其ZK rollup部署了以太坊虚拟机(EVM),允许以太坊开发人员从主区块链转移他们的智能合约,而无需使用不同的语言重新编程。去年12月,Polygon zkEVM上线最终测试网版本。[2023/2/15 12:07:08]

在 RISC Zero,我们把这些证明称为 「收据」(receipts),在博客的其余部分,我将使用这个术语。每张收据都包括一个加密标识符,表明进行了哪项计算,以及计算的任何公共输出的日志。虽然这可能看起来是一个简单的概念,但它意味着机器可以生成收据来「证明」计算已经完成。

术语 zkEVM 是用来描述在 EVM 字节码引擎上运行智能合约的软件,并为特定的计算(或交易)生成收据。这个软件通常可以证明两个或多个收据是有效的,并生成另一个收据。通过使用这种机制,zkEVM 可以运行许多交易,并使用一个收据来表示它,这被称为 「Rollup」。用 Solidity 编写的项目可以使用 zkEVMs 来扩展交易,而不是在链上进行所有计算,在区块链上发布一个单一的收据来代表许多发生在链外的交易。zkEVM 有很多类型,如果你想了解它们,你可以在这篇文章中阅读更多。

zkSync在Code4rena平台启动漏洞赏金计划:10月29日消息,以太坊Layer2扩容解决方案zkSync宣布在Code4rena平台启动漏洞赏金计划,总奖金池达165,000美元。活动将于北京时间10月29日4时开启,至11月10日4时结束,本次活动旨在提高网络安全性,使zkSync2.0成为更多开发人员的选择。[2022/10/29 11:55:24]

在 RISC Zero,我们实现了一个零知识虚拟机(zkVM),而不是一个 zkEVM。两者之间的区别在于,「VM」,即 「虚拟机」,比 EVM 更通用。

在 zkVM 上,你可以运行几乎所有在计算机上运行的软件,而不是任何可以在以太坊上运行的软件。这种计算机使用 RISC-V 架构,这是一套用于通用计算的指令。这意味着 RISC-V 并没有内置钱包地址或其他区块链结构的概念。该指令集主要由在内存位置之间移动数据和对数据进行数学运算的运算符组成。虽然这个指令集可能看起来过于笼统,但并不要求程序员知道如何用汇编语言编程,以便为这个 zkVM 编写程序。

与 EVM 相比,这个底层的 RISC-V 模拟器允许程序员用 Rust、C/C++ 和 Go 等语言为 zkVM 编写程序(注意,我们目前支持 Rust,我们对 C/C++ 和 Go 的支持目前正在进行中)。这意味着 zkVM 的程序员可以使用别人在该语言的生态系统中开发的相关库。一个例子是,我们可以运行玩 Wordle 或 Where’s Waldo 等游戏的程序。然而,我们并不局限于简单的游戏:你可以运行许多其他编译为 RISC-V 的程序。

如果你想了解更多帮助你写出更好的 DeFi 应用的框架,你可能会想知道为什么我们正在研究 RISC Zero 这样一个通用的计算框架。

通过允许用户使用通用语言编写程序,我们打开了在 Solidity 库之外编写代码的可能性。这意味着应用逻辑不需要局限于可以用 Solidity 表达的内容,并允许你写出与链无关的代码。像 Rust 这样的通用语言允许开发者比那些为特定目的而设计的语言更容易编写不同类型的程序。例如,你可以用 Rust 编写一个简单的算术计算器,它接受一个数学表达式作为输入,运行数学计算,并将解决方案作为输出返回。如果你增加这个计算器的复杂性,以支持常见的编程语言结构,如变量、循环和函数,你就实现了一个简单的语言解释器,将程序作为输入,运行程序,并将解决方案作为输出返回。这些程序可以被编译成 RISC-V 并在 RISC Zero 的 zkVM 上运行。有了 Rust,你可以使用现有的 crates 来为你的应用程序编程,而不是从头开始编写一切。

一个这样的库是 Rust 上的 revm crate。这个 crate 是用 Rust 编写的 EVM 的一个实现。通过使用这个 crate,我们可以在 zkVM 上运行一个 EVM 字节码解释器。这意味着你可以在运行在 zkVM 上的 EVM 字节码解释器上运行 solidity 合约! 通过这样做,zkVM 会产生一个收据,代表运行智能合约的 EVM 的执行。这在 Odra 的这篇博文中已经进行了探讨,并被 zkPoEx 团队用来提高 bug 赏金。

随着当前智能合约的复杂性增加,许多人发现他们维护的链上代码只会随着他们的开发而增加成本。换句话说,如果你的 DeFi 逻辑逐渐变得计算昂贵,或者你的链上游戏逻辑需要额外的计算能力,RISC Zero 的 zkVM 和即将推出的 Bonsai 网络允许你使用通用编程语言编写可扩展的链上代码。我在这篇博文中列举了几个例子,我们正处于真正可扩展的计算网络的最开始。

StarkNet

企业专栏

阅读更多

金色荐读

金色财经 善欧巴

迪新财讯

Chainlink预言机

区块律动BlockBeats

白话区块链

金色早8点

Odaily星球日报

MarsBit

Arcane Labs

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

水星链

[0:0ms0-1:257ms