Hyperledger Fabric 核心概念

file

一、说明

区块链是一个透明的,基于不可变模式的去中心化系统,核心就是一个分布式账本,记录网络上发生的所有交易。

区块链网络主要有三种类型:公共区块链、联盟区块链,以及私有区块链;我们熟知的比特币、以太坊这些数字货币其实就是属于公共区块链平台;

而今天要介绍的 Fabric 则是属于联盟链类型的;Fabric是一个企业级的分布式账本技术平台,也是目前应用最广泛的区块链项目。

本文将梳理区块链技术平台 Fabric 的核心概念与关键功能。

 

二、特点

Fabric与其他区块链平台对比有以下几个特点:

  • 开源:它是Linux基金会旗下的一个重量级区块链平台。

  • 身份管理:fabric和其他区块链系统的不同之处在于它是私有的,有准入资格授权的,并非一个公开的允许不明身份参与者进入网络的系统;它提供了一个成员身份服务,用于管理网络上的所有参与者和权限。

  • 隐私和保密:有一个通道的概念提供了交易隐私和机密性,一个Fabric的网络可以创建多个通道,任何未正式授权的网络成员都没办法看到或者访问通道上的任何数据;可以理解为就是支持多租户,通道与通道之间的数据都是隔离的。

  • 链码功能:智能合约在Fabric 中称之为链码,用于对账本的访问,例如写入交易信息,查询数据等等。

  • 模块化设计:Fabric实现了模块化架构,例如身份、排序、链码等服务和功能,都是可选的可插拔的非常灵活。

 

三、系统功能

Fabric的一个功能架构图:


file
  • 身份管理功能是通过PKI体系和CA模块来实现成员、权限还有证书的管理。
  • 分布式账本就是区块链网络的核心功能,记录着所有的交易信息。
  • 排序服务,类似一个裁判的角色,因为不同的交易顺序对最终的交易结果是有很大的影响的,所以这个排序服务主要是为了让所有的节点达成统一的共识,最终实现数据的一致性。
  • 网络通信方面,节点与节点之间的点对点通信是基于grpc协议,然后再通过gossip算法来实现去中心化的广播,意思就是不需要中心节点,通过任意一个节点以一传十,十传百的方式来把消息散播到全网。
  • 背书验证指的是背书策略,背书策略有很多种,例如我指定策略为大多数节点同意,意思就是一笔交易必需超过半数的节点都认证通过了,才能完成,这样就能有效的防御一些恶意的交易。
  • 链码服务是一个独立的应用程序,运行在隔离的Docker容器中,在链码部署的时候会自动生成链码的Docker镜像。

 

四、组件逻辑关系

file
  1. 图中的浅蓝色方块 N 代表整个区块链网络;
  2. 网络底部的 C通道 相当于是一个子链,一个区块链网络可以创建多个通道,通道与通道之间是数据隔离的,可以理解为是一个多租户系统;
  3. 一个通道上面可以部署多个 Peer 节 点为图中蓝色方块 P1P2,区块链网络主要由 Peer 节 点组成;
  4. 每个 Peer 节 点上都有一份 账本 的全量副本为红色的 L1,然后 智能合约 是部署在每个节点上的为黄色 S1,一个节点可以部署多个 智能合约
  5. 最后区块链网络外面的白色方块A指的是访问区块链的 应用,应用是通过通道来与节点上的账本进行交易的。

 

五、账本

账本是 Hyperledger Fabric 中的一个重要概念,它存储了有关业务对象的重要事实信息,其中既包括对象属性的当前值,也包括产生这些当前值的交易的历史。

账本由一个区块链(链)构成,并将不可变的、有序的记录存放在区块中;同时包含一个状态数据库来记录当前的Fabric状态。每个 通道 中各有 一个账本。各个节点对于它所属的每个通道,都会保存一份该通道的 账本副本

如下图所示,Hyperledger Fabric 中的账本由“世界状态“和”区块链“这两部分组成:

file

世界状态:世界状态是以数据库的形式实现,默认使用的是LevelDB,这是一个KeyValue数据库;里面记录的是业务对象的最新值;智能合约主要与账本中的世界状态进行交互。

区块链:以文件形式实现的,记录交易日志明细,相当于是一个交易的台账表。

例如有一个银行账户,发生一次存款和三次取款操作,则最终区块链里面会记录四条记录的日志,而世界状态则只记录一条记录,就是当前账户最新的余额。

 

六、智能合约

智能合约 是一个运行在账本上的应用程序,它可以对资产进行编码,其中的交易指令(或者叫业务逻辑)也可以用来修改资产。

Fabric2.0 以后引入了新的生命周期来管理合约:

file
  1. 首先第一步开发合约:需要依赖原生的合约 sdk,支持包括 Java、js 和 Golang 三种开发语言。
  2. 开完合约后,管理员可以使用 package 子命令来打包合约,并生成打包文件。打包命令默认程序是 golang 语言,可以使用 -l 参数来指定其他语言。
  3. 一次打包可以多次安装,然后接着使用 install 命令在指定的 peer 节点上安装合约。
  4. 安装成功后,接着使用 approveformyorg 命令代表所在机构审批合约,并且指定背书策略。
  5. 最后使用 commit 命令向指定的通道提交合约定义,执行完这一步智能合约就部署成功,正式生效了。
  6. 接下来我们就可以编写应用程序来与区块链网络进行交易了,Fabric 封装了一套网关 SDK 给应用程序使用,通过一系列的简单 API 就实现和区块链网络进行交互。

关于 Java 智能合约的开发可以看我之前的文章《Hyperledger Fabric 2.x 自定义智能合约

 

七、交易流程

file
  1. 首先区块链应用发起一笔交易;
  2. 然后 背书节点 对交易进行签名验证,返回验证结果;
  3. 客户端将背书结果封装发给 Peer 节点,然后再提交给 Order 节点进行数据同步;
  4. Order 节点按顺序把交易信息同步给其他的 Peer 节点进行验证和提交;
  5. 最后账本更新,完成整个交易。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容