Hyperledger Fabric 交易流程

2024-04-03 05:18

本文主要是介绍Hyperledger Fabric 交易流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Transaction Flow
本文件概述了在标准资产交换期间发生的交易机制。该方案包括两个clientA和B,他们购买和销售萝卜。他们分别在网络上有一个peer,通过peer发送他们的交易并与账本交互。
enter image description here

假设
此流程假定通道已设置并运行。应用程序用户registe并向组织的证书颁发机构(CA)enroll,并收回了必要的加密材料,用于向网络进行身份验证。

Chaincode(包含表示萝卜市场初始状态的一组键值对)被安装在peer上并在channel上实例化。Chaincode包含了定义一组交易指令和商定的萝卜价格的逻辑。Endorsement策略也被定为chaincode,指出peerA和对等体peerB必须支持任何交易。

Transaction Flow
Client A 初始化一个交易
Endorsing peers验证签名并执行交易
Proposal回应被检查
Client将endorsement装配到交易中
交易被验证并提交
账本更新
1. Client A 初始化一个交易
enter image description here
发生了什么? - 客户端A发送购买萝卜的请求。请求目标peerA和peerB谁分别代表clientA和clientB。Endorsement策略规定两个peer必须签署任何交易,因此请求转到peerA和peerB。

接下来,构建交易proposal。利用支持SDK(node,java,python)的应用程序使用可用的API之一来生成交易建议。该proposal是调用chaincode函数的请求,以便可以将数据读取和/或写入账本(即为资产写入新的键值对)。SDK用作中间件(shim),将交易proposal打包为适当的架构的格式(通过gRPC的协议缓冲区),并采用用户的加密凭证为该交易建议生成唯一的签名。

2. Endorsing peers验证签名并执行交易
enter image description here
Endorser验证1)交易proposal正确的组织,2)交易在之前并没有被提交(重访攻击保护),3)签名的合法性(使用MSP),4)提交者(示例中的客户端A)被正确地授权在该channel上执行建议的操作(即,每个endorser确保提交者满足channel的Writer策略)。Endorser将交易proposal作为输入invoked的chaincode的函数的参数,并针对当前状态数据库执行它们以产生包括响应值,读集和写集的交易结果。此时不会更新账本。这些值的集合,以及支持peer的签名和YES / NO认可语句作为“建议响应”传递回SDK,该SDK解析用于应用消费的有效载荷。

{MSP是在peer上运行的本地进程,它允许它们验证从客户端到达的交易请求并签署交易结果(endorsement)。ACL(访问控制列表)在信道创建时定义,并确定允许哪些对等端和最终用户执行某些操作。}

3. Proposal回应被检查
enter image description here
应用程序验证endorser签名并且比较proposal的响应(链接到包含有效载荷的表示的词汇表术语)以确定proposal响应是否相同以及是否已经满足指定的endorsement策略(即,是否peerA和peerB两者都endorse)。该架构使得即使应用程序选择不检查响应或以其它方式转发未endorsed的交易,该策略仍然将由peer实施并且在提交验证阶段被维护。

4. Client将endorsement装配到交易中
enter image description here
应用程序将“交易消息”中的交易proposal和响应“广播”到排序服务。交易将包含读/写集合,被承认的peer签名和channel ID。Ordering服务不会读取交易详细信息,它只是从网络中的所有渠道接收交易,根据channel安时间顺序对其进行排序,并为每个渠道创建交易块。

5. 交易被验证并提交
enter image description here
交易块被“传递”到信道上的所有peer。块内的交易被验证以确保endorsement策略被满足并且确保账本的read集变量状态没有改变,因为read集是由交易执行生成的。块中的交易标记为有效或无效。

6. 账本更新
每个peer将块附加到channel的链,并且对于每个有效交易,write集被提交到当前状态数据库。发出事件以通知客户端应用程序交易(调用)已被不可变地附加到链,以及通知交易是否被验证或无效。
enter image description here

这篇关于Hyperledger Fabric 交易流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/871994

相关文章

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请