博客
关于我
zkSync 基本原理
阅读量:298 次
发布时间:2019-03-01

本文共 1629 字,大约阅读时间需要 5 分钟。

1. 引言

zkSync作为以太坊的扩容和隐私引擎,支持或即将支持多项重要功能,包括低气交易(low gas transactions)和ERC20代币在以太坊网络上的支持、通过Zinc语言或Solidity实现可编程隐私智能合约以及对交易所友好的Atomic swap支持。这些功能使得zkSync成为DeFi和DApp开发者的理想选择。

2. zkSync中的基本概念

2.1 zkSync中的Operation

zkSync定义了两种主要的操作类型:

  • Priority Operation:直接在以太坊主网上运行,包括Deposit和FullExit两种类型。

    • Deposit:将资金从以太坊转移到zkSync指定地址,若地址不存在则创建并分配numeric ID。
    • FullExit:在无法设置zkSync签名或检测到审查时提取资金至以太坊。
  • Transaction:通过zkSync API提交,包括ChangePubKey、Transfer、Withdraw和ForcedExit四种类型。

    • ChangePubKey:设置或修改账号签名密钥,需提供两个签名以确保交易不可篡改。
    • Transfer:将资金从一个zkSync账号转移到另一个账号,若接收地址不存在则创建新账号。
    • Withdraw:将资金从zkSync提取至以太坊,需提供正确签名。
    • ForcedExit:提取资金至目标地址,适用于目标地址对应智能合约且无签名的情况。
  • 2.2 zkSync中的Block

    • zkSync操作通过block进行组织,block在提交后需等待验证前可用。
    • 通过mini-block技术,用户可分组提交交易,缩短等待时间。
    • 区块验证通过ZK证明在以太坊上发布,确保区块最终状态的正确性。

    2.3 zkSync中的Flow

  • 创建账号:可通过以太坊转账或zkSync交易创建,新账号需设置签名密钥。
  • 设置签名密钥:默认签名密钥为0值,需通过ChangePubKey交易设置。
  • 交易资金:支持ETH和ERC20代币,需通过合约批准交易金额。
  • 交易费用:费用基于交易数据量、gas价格和区块证明成本,整体费用较低。
  • 提取资金:支持Withdraw、ForceExit和FullExit三种方式。
  • 3. 向zkSync网络发送交易基本原则

  • 发送Priority Operation

    • 通过智能合约触发Deposit和FullExit操作。
    • Deposit需批准合约金额,FullExit需注册退出请求并完成提取。
  • 发送Transaction

    • 准备交易数据,签名并提交,需包含交易描述签名。
    • 交易类型包括ChangePubKey、Transfer、Withdraw和ForcedExit。
  • 发送Transactions Batch

    • 支持最多50笔交易,费用可通过最后一笔交易支付。
    • Batch交易签名需包含所有交易数据,确保批次成功或失败。
  • 4. zkSync中的智能合约

  • 智能合约语言支持

    • zkSync支持Zinc和Solidity语言,Zinc专为ZKP优化,Solidity兼容现有代码。
    • 智能合约可通过Ethereum签名调用,支持DeFi项目迁移。
  • 虚拟机(VM)设计

    • 基于PLONK证明,支持高效执行和快速交易。
    • 优化了bytecode和执行环境,确保交易速度和安全性。
  • 智能合约部署

    • 测试网络已于2020年10月启动,主网计划2021年支持Zinc和Solidity。
    • Rinkeby测试网部署教程可参考官方文档。
  • 5. zkSync 1.x中的NFT

  • NFT地址规则

    • 地址基于创建账户ID、序列号和内容哈希,确保唯一性和不可篡改性。
    • 支持多个NFT使用相同内容哈希,适合批量mint和转让。
  • NFT minting

    • 使用MINT_NFT opcode mint NFT,可指定创建者和接收者。
  • 参考资料

    [1] [2] [3] [4] [5]

    转载地址:http://pkqx.baihongyu.com/

    你可能感兴趣的文章
    NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
    查看>>
    Nodejs教程09:实现一个带接口请求的简单服务器
    查看>>
    nodejs服务端实现post请求
    查看>>
    nodejs框架,原理,组件,核心,跟npm和vue的关系
    查看>>
    Nodejs模块、自定义模块、CommonJs的概念和使用
    查看>>
    nodejs生成多层目录和生成文件的通用方法
    查看>>
    nodejs端口被占用原因及解决方案
    查看>>
    Nodejs简介以及Windows上安装Nodejs
    查看>>
    nodejs系列之express
    查看>>
    nodejs系列之Koa2
    查看>>
    Nodejs连接mysql
    查看>>
    nodejs连接mysql
    查看>>
    NodeJs连接Oracle数据库
    查看>>
    nodejs配置express服务器,运行自动打开浏览器
    查看>>
    Nodemon 深入解析与使用
    查看>>
    node不是内部命令时配置node环境变量
    查看>>
    node中fs模块之文件操作
    查看>>
    Node中同步与异步的方式读取文件
    查看>>
    Node中的Http模块和Url模块的使用
    查看>>
    Node中自启动工具supervisor的使用
    查看>>