Fabric 架构和概念

0x00

本文基于fabric 1.0.4版本,如果相关概念有所改动,请以官方文档为准

基本架构

fabric构建的区块链网络是一个分布式系统,包含了一些逻辑节点,这些逻辑节点各司其职,完整的执行着交易的发起,验证,账本状态更新,一致性等功能

主要概念

chaincode

chaincode是一个按照一定规范实现的应用程序,运行于容器中,chaincode可以被安装到peer上,应用程序(客户端)通过发起交易请求,endsorer peer执行chaincode并进行签名,经过orderer的验证后,下发到对应的channel中,对账本进行更新。

交易

fabric中的交易分为两种,一是发布chaincode到peer的deploy transaction,二是chaincode的执行,称为invoke transaction;其实还可能存在query transaction(v1版本加入)和cross-chaincode transaction(v1之后的版本会加入),不过不在本文讨论范围内。

Membership Service Provider

由于fabric提供了权限控制,因此,对于peer和client来说,对于交易的结果和交易本身,都需要进行授权,这个组件是一个抽象的接口,它定义了提供权限控制的一系列标准,对于不同的网络,可以通过注入不同的实现来实现自己的认证授权机制。

Member

member是fabric中最粗的逻辑单位,一个member可以类比于一个参与该交易网络的组织,例如在电商网络中,京东,淘宝都是一个member,这个member包含自己的root CA ,自己的集群用于维护账本。

区块链的结构

状态

整个区块链的状态可以看作是一个 versioned KVS(带有版本的 key-value store,类似于git仓库),这些kv通过chaincode(智能合约)进行更新,它只提供了put和get方法,所有的状态变更都有日志记录。


KVS状态结构

账本

如上所述,区块链的账本,其实就是其 KVS模型的当前状态。并且账本会记录所有的成功或失败的交易请求。账本的修改都来自于orderer下发的事件,其中包含了打包好的block,这些block中,既包含成功的交易,也包含失败的交易,经过排序后形成一个顺序存储的结构保存在block中,而账本(区块链)就是这样一个一个block首尾相连所形成的数据集合。

分布式账本

前文提到了,所有的node上,都会存在一个当前账本(或子集)的副本,是否是子集,取决于该节点所在的组织(organization)是否能看到所有的交易信息。而最全的账本,是在orderer node上,称之为orderer ledger,而存在于peer node上的账本,则称之为peerledger,peer还在本地维护了一个bitmap,用于标记ledger中哪些交易是invalid的,而ordererledger则主要作为(peerledger的)容错和高可用而存在。

node

fabric 1.0中,定义了三种node,分别是:

  1. client
  2. peer
  3. orderer

client

client模拟的是交易网络中的普通用户,普通用户连接到某个peer上,调用注册在该peer上的某个chaincode,从而完成对账本的更新

peer

peer node通过channel和orderer node建立了一种 发布/订阅的关系,orderer service会把其关心的息发通过channel发送给peer node,peer接收到这些交易后,就会更新本地账本(peerledger)的状态,peer可以说是fabric网络中最基本的节点,所有的账本和智能合约都存储在其中,同时,anchor peer负责某个org在某个网络中的代表,而lead peer则是本org的所有peer的首脑,order通过peer将数据的更新扩散到org

orderer

由于fabric是一个分布式系统,因此每个node上都存储着一个账本,而当各个节点要对账本状态的修改时,必须有一个机制保证所有的这些CUDR操作的一致性,这就是orderer service,orderer service由一些orderer node组成,将所有提交的交易进行排序,验证,然后分发给对这个交易感兴趣(订阅了某个channel)的member(organization),使副本和原始账本保持一致。

orderer API

broadcast(blob): 客户端使用这个API来发起一次提交请求,该消息blob会被endsor,然后将其结果发送给orderer
deliver(seqno, prevhash, blob):当orderer service验证了某个交易是有效性的(valid)后,会使用该API分发消息到对应的channel,所有订阅了这个channel的peer都会收到这个deliver消息,消息包含一个正整数序列号(seqno),前一个blob的hash值和blob消息体的

orderer特性

一言以蔽之,orderer有如下几个特性

  1. 一致性:经过orderer deliver的交易,seqno一定时,blob和prevhash都一样
  2. hash链的完整性:对于deliver(seqno, hash0, blob0)和deliver(seqno-1, hash1, blob1),HASH(seqno-1, hash1, blob1) == hash0
  3. 不会凭空创造交易:每一次deliver,都是由于一次boardcast产生的。
  4. 不会缺失交易:如果一个deliver(seqno, hash, blob)已经发生,那么一定有deliver(seqno-1, hash0, blob0) ... deliver(0, default-hash, blob)
  5. 不会重复交易:如果产生了两次 boardcast(blob),boardcast(blob1),则deliver(seqno1, hash, blob1)和deliver(seqno, hash0, blob)中,seqno1==seqno,
    hash==hash0,blob==blob1

channel

channel可以理解为一个独立的交易网络,每一个channel都维护着自己的账本,也可以理解为,一个账本对应了一个channel,这个channel中的账本的状态由所有订阅了该channel的member(organization)维护

更多概念可以参考 glossary

结论

总的来说,fabric的交易网络可以如下图所示:


transaction flow
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容