当前位置: 首页 > news >正文

Mina之账户模型

为了能真正提升自己的能力,而不是机械低效的Ctrl + C / Ctrl + V,先从基本概念入手,利用ChatGPT来弄懂Mina。

Mina

Mina Protocol 是一种轻量级区块链,被称为“世界上最轻的区块链”。其目标是通过极小的链上数据大小和强大的隐私保护技术解决传统区块链的扩展性和隐私问题

特点

  1. 固定大小的区块链

    • Mina 的区块链大小始终保持约 22 KB(相当于几条推文的大小)。
    • 采用 zk-SNARKs(零知识证明)的递归压缩技术,无需存储完整的区块链历史。
  2. 轻量化与去中心化

    • 用户可以运行一个完整的 Mina 节点,硬件需求极低(如普通手机或笔记本电脑)。
    • 降低了参与区块链网络的门槛,增强了去中心化。
  3. zkApps(零知识应用)

    • Mina 提供基于零知识证明的智能合约(zkApps),允许构建具有隐私保护功能的去中心化应用。
    • zkApps 支持在不泄露数据的情况下验证交易逻辑。
  4. 隐私优先

    • Mina 使用零知识证明保护链上交易和账户状态的隐私。
    • 用户可以证明某些条件成立(如拥有资产或满足某条件),而无需暴露详细数据。
  5. 与 Web3 集成

    • Mina 致力于成为 Web3 的轻量级入口,通过 zkApps 实现与现有区块链和互联网的无缝连接。

Mina账号模型

组成

  • Public Key(公钥)

    • Mina 中的账户由公钥标识。
    • 公钥是通过私钥生成的,用户通过签名交易来证明对账户的控制权。
  • Nonce

    • 每当用户发送一笔交易,nonce 值会递增,确保每笔交易的唯一性。
    • 用于防止重放攻击。
  • Balance(余额)

    • 账户的代币余额,单位是 Mina Token。
    • 用于支付交易费用(手续费)和账户操作。
  • Account State(账户状态)

    • 包含账户相关的状态信息,例如 zkApp 的存储状态(如果账户是 zkApp 合约账户)。
  • Permissions(权限)

    • 定义账户的操作权限,例如更新账户状态的权限、发送交易的权限等。
    • zkApp 的权限控制特别重要,因为它涉及到谁可以调用合约方法。
  • Delegate(委托人)

    • Mina 使用权益证明(Proof of Stake, PoS)作为共识机制,账户可以将其权益(余额)委托给验证者(Validator)。
    • 委托不需要转移资金,委托权仅影响共识机制中的投票权。
  • zkApp 信息

    • 如果账户是 zkApp 合约账户,它还会存储 zkApp 的相关信息:

      • 合约代码(被 zk-SNARK 编译后存储)。
      • 验证密钥,用于验证 zkApp 的零知识证明。

类型

普通账户
  • 标准用户账户,用于存储 Mina Token 和发送交易。

  • 典型功能:

    • 接收和发送 Mina Token。
    • 委托权益给验证者。
    • 支付交易费用。
zkApp 合约账户
  • 特殊账户,用于部署和运行 zkApps(Mina 的智能合约)。

  • 具有额外的属性:

    • 存储 zkApp 状态。
    • 包含验证 zk-SNARK 的逻辑。
  • zkApp 合约账户只能通过零知识证明来改变其状态,确保链上的隐私和效率。

存储与状态管理

  1. 轻量级状态存储

    • Mina 使用 zk-SNARK 技术压缩整个链的状态,因此链上的每个账户状态都可以通过零知识证明快速验证,而不需要存储完整历史记录。
  2. 状态更新

    • 当账户的余额、nonce 或 zkApp 状态发生变化时,这些变化会被打包到新的区块,并通过 zk-SNARK 更新全网状态。
  3. 账户初始化

    • 账户在 Mina 上首次出现时,需要被 "初始化"。
    • 初始化通常通过发送交易或部署 zkApp 合约完成
    • 未初始化的公钥不会被视为链上的账户。

相关操作

  1. 账户初始化
  • 当某个公钥首次接收 Mina Token 或 zkApp 部署时,该账户会在链上注册。
  1. 账户交易
  • Mina 的每笔交易都需要:

    • 签名:用私钥签名交易,证明操作权限。
    • Nonce:保证交易唯一性。
  1. zkApp 状态更新
  • zkApp 合约账户的状态只能通过零知识证明和链上的合约逻辑来修改。
  • 状态更新需要验证 zk-SNARK 的有效性。

独创性

  1. zk-SNARK 压缩链上状态
  • Mina 的区块链大小固定,账户状态由 zk-SNARK 的递归证明管理。
  • 每个账户的状态更新会通过 zk-SNARK 验证并合并到全局状态。
  1. 轻量化账户
  • 账户模型设计高度简洁,普通账户和 zkApp 合约账户都围绕 "状态压缩" 进行优化。
  1. 权限控制
  • zkApp 合约账户允许开发者设置精细的权限规则,确保只有经过验证的交易或方法调用能够更新账户状态

优势

  1. 轻量级与高效性

    • 不需要存储所有历史交易,只存储必要的状态信息。
    • 节省了存储和验证资源。
  2. 强大的隐私支持

    • zk-SNARK 技术保护了账户状态更新的隐私性。
    • zkApp 状态更新可以在不公开输入数据的情况下完成。
  3. 灵活性

    • 支持普通账户和 zkApp 合约账户的多样化需求。
    • 提供细粒度的权限控制,适应不同场景

更多相关内容,,,https://t.me/+XB-mhZfcnQExOTdl 

相关文章:

Mina之账户模型

为了能真正提升自己的能力,而不是机械低效的Ctrl C / Ctrl V,先从基本概念入手,利用ChatGPT来弄懂Mina。 Mina Mina Protocol 是一种轻量级区块链,被称为“世界上最轻的区块链”。其目标是通过极小的链上数据大小和强大的隐私…...

STM32 ADC 配置

ADC(模数转换器)用于将模拟信号转换为数字信号,以便单片机处理。 模数转换器(Analog-to-Digital Converter, ADC)是电子系统中不可或缺的一部分,它负责将现实世界中的连续物理量,如温度、声音、…...

练9:进制转换

欢迎大家订阅【蓝桥杯Python每日一练】 专栏,开启你的 Python数据结构与算法 学习之旅! 文章目录 1 进制转换2 例题分析 1 进制转换 ①任意制转为十进制 【示例】 ②十进制转为任意制 【法一】 【法二】 2 例题分析 题目地址:https:/…...

善于运用指针--函数与指针

文章目录 前言一、函数的指针二、函数指针运用 1函数名地址2指针变量调用函数3指向函数的指针变量做函数参数二、返回指针值的函数总结 前言 如果在程序中定义了一个函数,在编译时会把函数的源代码转换为可执行代码并分配一段空间。这段空间有一个起始地址&#xf…...

Microi吾码低代码平台:前端源码的本地运行探索

文章目录 1.前端源码运行环境要求1.1 操作系统1.2 必备软件工具1.3 项目源码依赖 2.从Git仓库克隆前端源码3.安装项目依赖4.启动本地开发服务器5.常见问题与解决方案5.1 依赖安装失败5.2 端口冲突5.3 代码更新未生效 6.提升本地开发体验的技巧6.1 使用代理解决跨域问题6.2 集成…...

十一、容器化 vs 虚拟化-Docker 使用

文章目录 前言一、Docker Hello World二、Docker 容器使用三、Docker 镜像使用四、Docker 容器连接五、Docker 仓库管理六、Docker Dockerfile七、Docker Compose八、Docker Machine九、Swarm 集群管理 前言 Docker 使用‌ Docker 容器使用、镜像使用、容器连接、仓库管理、Do…...

实践项目2-自动计价电子秤

自动计价电子秤 一、功能说明 基于AVR单片机设计一自动计价电子秤。根据输入的价格以及检测的重量自动计算总价并打印(串口模拟)。 二、具体要求 1、开机后实时检测重量并显示; 2、通过按键输入并显示价格,具有修改功能&#…...

iOS如何操作更新推送证书

最近收到一份邮件,应该如何操作呢,证书还是跟以前一样冲钥匙串直接申请吗 Hello, As we announced in October, the Certification Authority (CA) for Apple Push Notification service (APNs) is changing. APNs will update the server certificates in sandbox on January…...

WSL2 在vscode无法连接copilot

报错情况: 本机可以使用copilot,但在WSL2上无法连接,报错信息如下: 检查网络情况: ping api.github.com 发现无法连接: github.com:Temporary failure in name resolution 在网上搜集的解决方法&#…...

HTA8998 实时音频跟踪的高效内置升压2x10W免电感立体声ABID类音频功放

1、特征 输出功率(fIN1kHz,RL4Ω,BTL) VBAT 4V, 2x10.6W(VOUT9V,THDN10%) VBAT 4V, 2x8.6W (VOUT9V,THDN1%) 内置升压电路模式可选择:自适应实时音频跟踪 升压(可提升播放时间50%以上)、强制升压 最大升压值可选择,升压限流值可设置 ACF防破音功能 D类…...

用ChatGPT-o1进行论文内容润色效果怎么样?

目录 1.引导问题发现 2.角色设定 3.整理常问修改 4.提供样例 5.小细节 小编在这篇文章中分享如何充分利用ChatGPT-o1-preview来提升论文润色的技巧。小编将持续跟进最新资源和最新的调研尝试结果,为宝子们补充更多实用的写作技巧。这些技巧将有助于您更有效地利…...

《探索 Jetpack Compose:构建现代化 Android UI 的利器》

Jetpack Compose 是谷歌推出的现代化 UI 框架,用于简化 Android 应用开发中的 UI 构建。它使用声明式编程方式,允许开发者以简洁直观的方式创建动态和响应式的 UI。本文将从基础概念到进阶用法,带你全面了解 Compose 的核心功能和使用技巧。 …...

cocos creator 的 widget组件的使用及踩坑

以下的内容基于cocos creator 3.8版本,如有错误,恳请指出。 👉官方文档的指引 应用:以上官方指引有非常清晰的使用方式,接下来说明一些注意事项: 1、与canvas搭配的使用,解决多分别率适配问题。…...

Baumer工业相机的EMVA1288 数据报告简介

项目场景: Baumer工业相机堡盟VCX系列和VLX系列为堡盟全系列相机中的主流常用相机和高端相机,性能强大、坚固可靠,易于集成,常用与一般行业的检测定位识别使用。 对应的高端相机系列具有极为丰富的强大技术功能,可轻…...

Docker 安装 中文版 GitLab

Docker 安装系列 安装GitLab、解决服务器内存不足问题、使用域名/IP地址访问项目 1、拉取 [rootTseng ~]# docker pull twang2218/gitlab-ce-zh:latest latest: Pulling from twang2218/gitlab-ce-zh 8ee29e426c26: Pull complete 6e83b260b73b: Pull complete e26b65fd11…...

uni-app 个人课程表页面

uni-app 个人课程表页面 插件参考地址 大部分代码都是参考了上述代码&#xff0c;只对代码做出了优化 1. 页面模板 在 schedule.vue 文件中&#xff0c;编写页面结构&#xff1a; <template><view><u-navbar title"个人中心"><view class&q…...

FPGA工作原理、架构及底层资源

FPGA工作原理、架构及底层资源 文章目录 FPGA工作原理、架构及底层资源前言一、FPGA工作原理二、FPGA架构及底层资源 1.FPGA架构2.FPGA底层资源 2.1可编程输入/输出单元简称&#xff08;IOB&#xff09;2.2可配置逻辑块2.3丰富的布线资源2.4数字时钟管理模块(DCM)2.5嵌入式块 …...

【OpenCV】平滑图像

二维卷积(图像滤波) 与一维信号一样&#xff0c;图像也可以通过各种低通滤波器&#xff08;LPF&#xff09;、高通滤波器&#xff08;HPF&#xff09;等进行过滤。LPF 有助于消除噪音、模糊图像等。HPF 滤波器有助于在图像中找到边缘。 opencv 提供了函数 **cv.filter2D()**&…...

LeetCode300. 最长递增子序列(2024冬季每日一题 30)

给你一个整数数组 nums &#xff0c;找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列&#xff0c;删除&#xff08;或不删除&#xff09;数组中的元素而不改变其余元素的顺序。例如&#xff0c;[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的 子序列。 示例 1&…...

vue H5如何实现copy功能

vue H5如何实现copy功能 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><link rel"stylesheet" href"https://unpkg.com/vant2.12/lib/index.css" /><title></title><st…...

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…...

Docker 离线安装指南

参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性&#xff0c;不同版本的Docker对内核版本有不同要求。例如&#xff0c;Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本&#xff0c;Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...

手游刚开服就被攻击怎么办?如何防御DDoS?

开服初期是手游最脆弱的阶段&#xff0c;极易成为DDoS攻击的目标。一旦遭遇攻击&#xff0c;可能导致服务器瘫痪、玩家流失&#xff0c;甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案&#xff0c;帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...

Oracle查询表空间大小

1 查询数据库中所有的表空间以及表空间所占空间的大小 SELECTtablespace_name,sum( bytes ) / 1024 / 1024 FROMdba_data_files GROUP BYtablespace_name; 2 Oracle查询表空间大小及每个表所占空间的大小 SELECTtablespace_name,file_id,file_name,round( bytes / ( 1024 …...

智慧工地云平台源码,基于微服务架构+Java+Spring Cloud +UniApp +MySql

智慧工地管理云平台系统&#xff0c;智慧工地全套源码&#xff0c;java版智慧工地源码&#xff0c;支持PC端、大屏端、移动端。 智慧工地聚焦建筑行业的市场需求&#xff0c;提供“平台网络终端”的整体解决方案&#xff0c;提供劳务管理、视频管理、智能监测、绿色施工、安全管…...

【Java学习笔记】Arrays类

Arrays 类 1. 导入包&#xff1a;import java.util.Arrays 2. 常用方法一览表 方法描述Arrays.toString()返回数组的字符串形式Arrays.sort()排序&#xff08;自然排序和定制排序&#xff09;Arrays.binarySearch()通过二分搜索法进行查找&#xff08;前提&#xff1a;数组是…...

WordPress插件:AI多语言写作与智能配图、免费AI模型、SEO文章生成

厌倦手动写WordPress文章&#xff1f;AI自动生成&#xff0c;效率提升10倍&#xff01; 支持多语言、自动配图、定时发布&#xff0c;让内容创作更轻松&#xff01; AI内容生成 → 不想每天写文章&#xff1f;AI一键生成高质量内容&#xff01;多语言支持 → 跨境电商必备&am…...

Webpack性能优化:构建速度与体积优化策略

一、构建速度优化 1、​​升级Webpack和Node.js​​ ​​优化效果​​&#xff1a;Webpack 4比Webpack 3构建时间降低60%-98%。​​原因​​&#xff1a; V8引擎优化&#xff08;for of替代forEach、Map/Set替代Object&#xff09;。默认使用更快的md4哈希算法。AST直接从Loa…...

解析两阶段提交与三阶段提交的核心差异及MySQL实现方案

引言 在分布式系统的事务处理中&#xff0c;如何保障跨节点数据操作的一致性始终是核心挑战。经典的两阶段提交协议&#xff08;2PC&#xff09;通过准备阶段与提交阶段的协调机制&#xff0c;以同步决策模式确保事务原子性。其改进版本三阶段提交协议&#xff08;3PC&#xf…...

基于开源AI智能名片链动2 + 1模式S2B2C商城小程序的沉浸式体验营销研究

摘要&#xff1a;在消费市场竞争日益激烈的当下&#xff0c;传统体验营销方式存在诸多局限。本文聚焦开源AI智能名片链动2 1模式S2B2C商城小程序&#xff0c;探讨其在沉浸式体验营销中的应用。通过对比传统品鉴、工厂参观等初级体验方式&#xff0c;分析沉浸式体验的优势与价值…...