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 中被废弃)
我曾七次鄙视自己的灵魂:
第一次,当它本可进取时,却故作谦卑;
第二次,当它空虚时,用爱欲来填充;
第三次,在困难和容易之间,它选择了容易;
第四次,它犯了错,却借由别人也会犯错来宽慰自己;
第五次,它自由软弱,却把它认为是生命的坚韧;
第六次,当它鄙夷一张丑恶的嘴脸时,却不知那正是自己面具中的一副;
第七次,它侧身于生活的污泥中虽不甘心,却又畏首畏尾。
第一次,当它本可进取时,却故作谦卑;
第二次,当它空虚时,用爱欲来填充;
第三次,在困难和容易之间,它选择了容易;
第四次,它犯了错,却借由别人也会犯错来宽慰自己;
第五次,它自由软弱,却把它认为是生命的坚韧;
第六次,当它鄙夷一张丑恶的嘴脸时,却不知那正是自己面具中的一副;
第七次,它侧身于生活的污泥中虽不甘心,却又畏首畏尾。