Hyperledger Fabric【区块链学习一】
Hyperledger Fabric 学习
什么是区块链
- 什么是区块链在我们没有接触的时候,只知道它是一个去中心化的存储方式。当我们发生交易,或者动作的时候我们会将记录通知给所有参与者共同维护,达到去中心化的进行存储。并且我们会将记录使用加密技术保证记录一旦添加到了账本中就无法修改(无法修改的账本就可以追溯信息根源)这个也就是区块链有时候被称为证明系统。
区块链使用场景
- 多方参与
- 跨机构数据共享需求
- 能够除本增收
- 提高工作效率
智能合约
- 智能合约也就是我们说的链码,我们可以通过智能合约访问我们的账本,还可以在不同的场景下通过智能合约达到不同的变化,也好比如我们写的代码。
共识
- 保证账本在整个网络中同步的过程就叫做共识,该过程确保账本仅在交易被相应参与者批准时更新,并且当账本更新时,它们以相同的顺序更新相同的交易。
什么是Hyperledger Fabric
Hyperledger Fabric 是 Hyperledger 中的区块链项目之一。与其他区块链技术一样,它有一个账本,使用智能合约,是一个参与者管理交易的系统。
- Hyperledger Fabric与其他区块链不同的是私有、许可。与允许未知身份与网络的开放式非许可系统(需要诸如“工作量证明”之类的协议来验证交易并保护网络)不同,Hyperledger Fabric 网络的成员需要从可信赖的 成员服务提供者(MSP) 注册。
Membership Services Provider (MSP)。 MSP是证书颁发机构,以管理用于认证成员身份和角色的证书。在Hyperledger Fabric网络中,所有的节点必须要有认证过的身份才能进行交易。MSP管理用户ID并验证网络上的所有参与者,从而使Hyperledger Fabric成为一个私有的和准入的网络。
- Hyperledger Fabric 还提供多种可插拔选项。账本数据可以以多种格式存储,共识机制可以交换替换,并且支持不同的MSP。
- Hyperledger Fabric 还提供创建管道功能,显示管道通讯隔离,没有加入这个管道你就没有这个管道通知信息。
- 针对交易 Fabric 引入了一种新的架构,我们称为执行-排序-验证。为了解决顺序执行模型面临的弹性、灵活性、可伸缩性、性能和机密性问题,它将交易流分为三个步骤:
- 执行一个交易并检查其正确性,从而给它背书,
- 通过(可插拔的)共识协议将交易排序,
- 提交交易到账本前先根据特定应用程序的背书策略验证交易
共享账本
Hyperledger Fabric 有一个账本子系统,包含两个组件:世界状态和交易状态,每个参与者都拥有他们所属的Hyperledger Fabric 网络的账本副本
- 世界状态组件:描述在给定时间点账本的状态,它是账本的数据库。数据存储方式可以替换,默认是LevelDB键值存储数据库(简称:数据库)
- 交易日志组件:记录产生世界状态中当前值得所有交易,是世界状态的更新历史,它只记录区块链网络使用的账本数据库前后的值(简称:日志)
智能合约
- Hyperledger Fabric 智能合约用链码进行编写,当应用程序需要与账本发生交互,由区块链外部的应用程序调用。一般链码只与账本的世界状态(数据库)交互、不与交易日志发生交互
隐私
- 当我们的数据需要注意隐私问题,Hyperledger Fabric 提供支持私有网络,也就是我们说的通道进行隔离产生一个私有网络
共识
- 我们的交易必须按照发生的顺序写入我们的账本中,即使它们在网络中不同参与者不同的集合中,为保证顺序、合法性、账本状态 一致。 Hyperledger Fabric 提供了一些容错机制比如:PBFT(拜占庭容错算法)
身份
- 区块链网络中不同的参与者包括Peer节点、排序节点、客户端应用程序、管理员等,都具有一个封装在X.509数字证书。这个身份代表着你能访问到的资源。
成员
- 就相当于合法的公民,这里的话就要配合成员服务者(MSP)验证成员的有效身份信息。(形影不离,通常结合使用)
策略
- 比如我们要做一个时间有什么前提条件,智能合约背书策略 链码包中的每一个智能合约都有一个背书策略,该策略指明了需要通道中多少不同组织的成员根据指定智能合约执行和验证交易才能使一笔交易有效。因此,背书策略定义了必须“背书”(批准)提案执行的组织(的 Peer 节点)。
Peer节点
- 区块链网络主要是由Peer节点组成,Peer是网络的基本元素,因为他们存储了账本和智能合约。一个成员可以有多个Peer节点,但是主要分为主节点、背书节点、记账节点、排序节点
- 当发生通讯时只会有一个节点进行确认,然后通过主节点进行通知组织中其他Peer
排序节点和交易流程(执行、排序、验证)
- 提案
- 客户端应用程序将交易发送给一组节点,这些节点会调用智能合约生成账本更新提案,然后进行背书审核。
- 将交易排序并打包到区块中
- 但我们背书成功之后,我们会交易提交到排序服务节点,排序服务创建交易区块,最终这些交易区块将分发给管道所有的Peer节点
- 验证和提交
- 每个节点将独立地以确定的方式验证区块,以确保账本保持一致。
排序服务实现
- Raft (推荐) 、 Kafka (在 v2.0 中被废弃) 、 Solo (在 v2.0 中被废弃)
Hyperledger Fabric【区块链学习一】的更多相关文章
- 区块链学习7:超级账本项目Fabric中的背书、背书节点、背书策略、背书签名
☞ ░ 前往老猿Python博文目录 ░ 在Hyperledger Fabric区块链中,有背书节点进行背书,Hyperledger Fabric 使用背书策略来定义哪些节点需要执行交易. Hyper ...
- Hyperledger Fabric 手动搭建【区块链学习三】
Hyperledger Fabric 手动搭建 前面我们学习了区块链是什么.还有自动搭建学习东西我们就要从简单到深入(入门到放弃),现在自动部署已经跑通了接下来就是手动搭建Fabric 网络可以更好的 ...
- 区块链学习7:超级账本项目Hyperledger与Fabric以及二者的关系
☞ ░ 前往老猿Python博文目录 ░ 一.超级账本(hyperledger) 超级账本(hyperledger)是Linux基金会于2015年发起的推进区块链数字技术和交易验证的开源项目,成员包括 ...
- Hyperledger Fabric 2.2 学习笔记:测试网络test-network
写在前面 最近被Hyperledger Fabric折磨,归根结底还是因为自己太菜了qwq.学习路漫漫,笔记不能少.下面的步骤均是基于已经成功搭建了Fabric2.2环境,并且拉取fabric-sam ...
- Hyperledger Fabric 1.0 学习搭建 (五)--- 启动Fabric多节点集群
5.1.启动orderer节点服务 上述操作完成后,此时各节点的compose配置文件及证书验证目录都已经准备完成,可以开始尝试启动多机Fabric集群. 首先启动orderer节点,切换至order ...
- Hyperledger Fabric 1.0 学习搭建 (四)--- 创建Fabric多节点集群
4.1.配置说明 首先可以根据官方Fabric自带的e2e_cli列子中的集群方案来生成我们自己的集群,与案例不同的是我们需要把容器都分配到不同的服务器上,彼此之间通过网络来进行通信,网络构建完成后则 ...
- Hyperledger Fabric 1.0 学习搭建 (三)--- 运行测试e2e-Fabric
3.1.运行fabric-samples的问题说明 该问题说明能够解决6.1.平台特定使用的二进制文件配置第一步的问题.可以选择继续阅读该说明,或者等参考到6.1小节时再反向阅读本说明,具体在6.1中 ...
- 区块链学习笔记:D03 区块链在各行业领域的应用(一)
今天主要是学习了区块链在金融和供应链领域的应用,重点体现了区块链多方参与.透明可信.防篡改防抵赖的技术优势 区块链的应用场景最早是在金融行业应用较多,后续逐步扩展到传统行业,如:供应链.政务服务.物联 ...
- 区块链学习笔记:DAY01 区块链的技术原理
其实很早之前就听过区块链,也看过有关区块链的介绍,那个时候的理解主要还是一句话:分布式记账 然后开始关注比特币,听了有几年了,对于其来历.用途其实一直都是一知半解. 这次的课算是第一次以一个学员的身份 ...
随机推荐
- 前端学习(十四):CSS布局
进击のpython ***** 前端学习--CSS布局 每个模块的相关央视就算是进本上都完成了,但是,这些模块想放在不同的位置 横着放,竖着放,斜着放... ... 想怎么放怎么放 那就用到了今天要说 ...
- fgdsafhak
- 监督学习-KNN最邻近分类算法
分类(Classification)指的是从数据中选出已经分好类的训练集,在该训练集上运用数据挖掘分类的技术建立分类模型,从而对没有分类的数据进行分类的分析方法. 分类问题的应用场景:用于将事物打上一 ...
- Salt组件(二)
四.配置管理States 是SaltStack中的配置语言,在日常进行配置管理时需要编写大量的States文件.比如我们需要安装一个包,然后管理一个配置文件,最后保证某个服务正常运行.这里就需要我们编 ...
- Java 线程池记录
Java通过Executors提供四种线程池,分别为:newCachedThreadPool创建一个可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程.newFixe ...
- Redis服务之常用配置(二)
上一篇博客我们聊了下redis的INCLUDE.NETWORK.GENERAL配置段相关配置和说明,回顾请参考:https://www.cnblogs.com/qiuhom-1874/p/133831 ...
- Using platform encoding (UTF-8 actually) to copy filtered resources, i.e. build is platform!
原文链接:https://blog.csdn.net/u012700515/article/details/56009429 Maven 打包时有标题中警告,需要在pom.xml文件中添加 <p ...
- PHP 循环 - While 循环
PHP 循环 - While 循环 循环执行代码块指定的次数,或者当指定的条件为真时循环执行代码块. PHP 循环 在您编写代码时,您经常需要让相同的代码块一次又一次地重复运行.我们可以在代码中使用循 ...
- FreeSql增加新特性Context
源 FreeSql 作者做了很完善的组件 我看了一下,感觉很实用,使用上有很大的可自定义操作的地方,跟传统Orm固定格式不同,也异于Dapper的设计,支持表达式树 原地址 https://www.c ...
- 【NOIP2017】跳房子 题解(单调队列优化线性DP)
前言:把鸽了1个月的博客补上 ----------------- 题目链接 题目大意:机器人的灵敏性为$d$.每次可以花费$g$个金币来改造机器人,那么机器人向右跳的范围为$[min(d-g,1),m ...