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【区块链学习一】的更多相关文章

  1. 区块链学习7:超级账本项目Fabric中的背书、背书节点、背书策略、背书签名

    ☞ ░ 前往老猿Python博文目录 ░ 在Hyperledger Fabric区块链中,有背书节点进行背书,Hyperledger Fabric 使用背书策略来定义哪些节点需要执行交易. Hyper ...

  2. Hyperledger Fabric 手动搭建【区块链学习三】

    Hyperledger Fabric 手动搭建 前面我们学习了区块链是什么.还有自动搭建学习东西我们就要从简单到深入(入门到放弃),现在自动部署已经跑通了接下来就是手动搭建Fabric 网络可以更好的 ...

  3. 区块链学习7:超级账本项目Hyperledger与Fabric以及二者的关系

    ☞ ░ 前往老猿Python博文目录 ░ 一.超级账本(hyperledger) 超级账本(hyperledger)是Linux基金会于2015年发起的推进区块链数字技术和交易验证的开源项目,成员包括 ...

  4. Hyperledger Fabric 2.2 学习笔记:测试网络test-network

    写在前面 最近被Hyperledger Fabric折磨,归根结底还是因为自己太菜了qwq.学习路漫漫,笔记不能少.下面的步骤均是基于已经成功搭建了Fabric2.2环境,并且拉取fabric-sam ...

  5. Hyperledger Fabric 1.0 学习搭建 (五)--- 启动Fabric多节点集群

    5.1.启动orderer节点服务 上述操作完成后,此时各节点的compose配置文件及证书验证目录都已经准备完成,可以开始尝试启动多机Fabric集群. 首先启动orderer节点,切换至order ...

  6. Hyperledger Fabric 1.0 学习搭建 (四)--- 创建Fabric多节点集群

    4.1.配置说明 首先可以根据官方Fabric自带的e2e_cli列子中的集群方案来生成我们自己的集群,与案例不同的是我们需要把容器都分配到不同的服务器上,彼此之间通过网络来进行通信,网络构建完成后则 ...

  7. Hyperledger Fabric 1.0 学习搭建 (三)--- 运行测试e2e-Fabric

    3.1.运行fabric-samples的问题说明 该问题说明能够解决6.1.平台特定使用的二进制文件配置第一步的问题.可以选择继续阅读该说明,或者等参考到6.1小节时再反向阅读本说明,具体在6.1中 ...

  8. 区块链学习笔记:D03 区块链在各行业领域的应用(一)

    今天主要是学习了区块链在金融和供应链领域的应用,重点体现了区块链多方参与.透明可信.防篡改防抵赖的技术优势 区块链的应用场景最早是在金融行业应用较多,后续逐步扩展到传统行业,如:供应链.政务服务.物联 ...

  9. 区块链学习笔记:DAY01 区块链的技术原理

    其实很早之前就听过区块链,也看过有关区块链的介绍,那个时候的理解主要还是一句话:分布式记账 然后开始关注比特币,听了有几年了,对于其来历.用途其实一直都是一知半解. 这次的课算是第一次以一个学员的身份 ...

随机推荐

  1. 笨办法学Python 3|百度网盘免费下载|新手基础入门书籍

    点击下方即可百度网盘免费提取 百度网盘免费下载:笨办法学Python 3 提取码:to27 内容简介: 本书是一本Python入门书,适合对计算机了解不多,没有学过编程,但对编程感兴趣的读者学习使用. ...

  2. pillow 压缩和放大图片

    记住这个  resize()方法 from PIL import Image img=Image.open("test.png") x,y=img.size print(x,y) ...

  3. Logback配置文件这么写,还愁不会整理日志?

    摘要: 1.日志输出到文件并根据LEVEL级别将日志分类保存到不同文件 2.通过异步输出日志减少磁盘IO提高性能 3.异步输出日志的原理 1.配置文件logback-spring.xml Spring ...

  4. 让内层浮动的Div将外层Div撑开 -----清浮动

    清浮动的好处写多了都能体会到,解决高度塌陷, 一般情况下是要清除浮动的,不然会影响下面标签的排版. <div class="parent" style="width ...

  5. RHEL7配置ip地址

    通过修改ifcfg-eno16777728配置文件来修改配置ip 网卡命令格式:eno16777728 en:代表enthernet(以太网) o:代表onboard(内置) 16777728:是主板 ...

  6. 360随身WiFi3:纯净版无线网卡驱动下载及安装教程(Windows10版本)

    对于不带无线网卡的台式机,买一个360随身WiFi当无线网卡是很省钱的方法.但是这个随身WiFi3用的芯片较为奇葩,Win10下不太好找驱动.什么,你问我为啥不用360官网上的驱动?那个“驱动”装了之 ...

  7. 在npm发布自己造的轮子

    提到封装组件,发布到npm,很多同学都会觉得很神秘.但其实,npm包无非就是我们平时写的比较独立且可复用的模块.当然,想要发布,除了基础组件的编写外,还要进行一些包装.下文通过一个简单的案例,和大家一 ...

  8. PHP deg2rad() 函数

    实例 把角度转换为弧度: <?phpecho deg2rad("45") . "<br>";echo deg2rad("90&quo ...

  9. Lambda表达式运行原理

    目录 一.创建测试样例 二.利用Java命令编译分析 三.文末 JDK8引入了Lambda表达式以后,对我们写代码提供了很大的便利,那么Lambda表达式是如何运用简单表示来达到运行效果的呢?今天,我 ...

  10. JS——变量提升和函数提升

    一.引入 在了解这个知识点之前,我们先来看看下面的代码,控制台都会输出什么 var foo = 1; function bar() { if (!foo) { var foo = 10; } aler ...