# Fabric 1.0源代码笔记 之 Orderer #multichain(多链支持包)
## 1、multichain概述
multichain代码集中在orderer/multichain目录下,目录结构如下:
* manager.go,Manager接口定义及实现。
* chainsupport.go,ChainSupport接口定义及实现。
* systemchain.go,system chain。
## 2、Manager接口定义及实现
### 2.1、Manager接口定义
用于链的创建和访问。
```go
type Manager interface {
//获取ChainSupport,以及判断链是否存在
GetChain(chainID string) (ChainSupport, bool)
//获取系统通道的通道ID
SystemChannelID() string
//支持通道创建请求
NewChannelConfig(envConfigUpdate *cb.Envelope) (configtxapi.Manager, error)
}
//代码在orderer/multichain/manager.go
```
### 2.2、Manager接口实现
Manager接口实现,即multiLedger结构体及方法。
```go
type multiLedger struct {
chains map[string]*chainSupport
consenters map[string]Consenter
ledgerFactory ledger.Factory
signer crypto.LocalSigner
systemChannelID string
systemChannel *chainSupport
}
type configResources struct {
configtxapi.Manager
}
type ledgerResources struct {
*configResources
ledger ledger.ReadWriter
}
//代码在orderer/multichain/manager.go
```
涉及方法如下:
```go
func (cr *configResources) SharedConfig() config.Orderer
//获取配置交易Envelope
func getConfigTx(reader ledger.Reader) *cb.Envelope
//构造multiLedger
func NewManagerImpl(ledgerFactory ledger.Factory, consenters map[string]Consenter, signer crypto.LocalSigner) Manager
//获取系统链ID
func (ml *multiLedger) SystemChannelID() string
//按chainID获取ChainSupport
func (ml *multiLedger) GetChain(chainID string) (ChainSupport, bool)
//构造ledgerResources
func (ml *multiLedger) newLedgerResources(configTx *cb.Envelope) *ledgerResources
//创建新链
func (ml *multiLedger) newChain(configtx *cb.Envelope)
//通道或链的个数
func (ml *multiLedger) channelsCount() int
//支持创建新的通道
func (ml *multiLedger) NewChannelConfig(envConfigUpdate *cb.Envelope) (configtxapi.Manager, error)
//代码在orderer/multichain/manager.go
```
func NewManagerImpl(ledgerFactory ledger.Factory, consenters map[string]Consenter, signer crypto.LocalSigner) Manager代码如下:
```go
func NewManagerImpl(ledgerFactory ledger.Factory, consenters map[string]Consenter, signer crypto.LocalSigner) Manager {
ml := &multiLedger{
chains: make(map[string]*chainSupport),
ledgerFactory: ledgerFactory,
consenters: consenters,
signer: signer,
}
existingChains := ledgerFactory.ChainIDs()
for _, chainID := range existingChains {
rl, err := ledgerFactory.GetOrCreate(chainID)
configTx := getConfigTx(rl)
ledgerResources := ml.newLedgerResources(configTx)
chainID := ledgerResources.ChainID()
if _, ok := ledgerResources.ConsortiumsConfig(); ok { //系统链
chain := newChainSupport(createSystemChainFilters(ml, ledgerResources), ledgerResources, consenters, signer)
ml.chains[chainID] = chain
ml.systemChannelID = chainID
ml.systemChannel = chain
defer chain.start()
} else { //普通链
chain := newChainSupport(createStandardFilters(ledgerResources), ledgerResources, consenters, signer)
ml.chains[chainID] = chain
chain.start()
}
}
return ml
}
//代码在orderer/multichain/manager.go
```
## 3、ChainSupport接口定义及实现
### 3.1、ChainSupport接口定义
```go
type ChainSupport interface {
PolicyManager() policies.Manager //策略管理
Reader() ledger.Reader
Errored() <-chan struct{}
broadcast.Support
ConsenterSupport //嵌入ConsenterSupport接口
Sequence() uint64
//支持通道更新
ProposeConfigUpdate(env *cb.Envelope) (*cb.ConfigEnvelope, error)
}
type ConsenterSupport interface {
crypto.LocalSigner
BlockCutter() blockcutter.Receiver
SharedConfig() config.Orderer
CreateNextBlock(messages []*cb.Envelope) *cb.Block
WriteBlock(block *cb.Block, committers []filter.Committer, encodedMetadataValue []byte) *cb.Block
ChainID() string
Height() uint64
}
type Consenter interface { //定义支持排序机制
HandleChain(support ConsenterSupport, metadata *cb.Metadata) (Chain, error)
}
type Chain interface {
//接受消息
Enqueue(env *cb.Envelope) bool
Errored() <-chan struct{}
Start() //开始
Halt() //挂起
}
//代码在orderer/multichain/chainsupport.go
```
### 3.2、ChainSupport和ConsenterSupport接口实现
ChainSupport接口实现,即chainSupport结构体及方法。
```go
type chainSupport struct {
*ledgerResources
chain Chain
cutter blockcutter.Receiver
filters *filter.RuleSet
signer crypto.LocalSigner
lastConfig uint64
lastConfigSeq uint64
}
//代码在orderer/multichain/chainsupport.go
```
涉及方法如下:
```go
//构造chainSupport
func newChainSupport(filters *filter.RuleSet,ledgerResources *ledgerResources,consenters map[string]Consenter,signer crypto.LocalSigner,) *chainSupport
func createStandardFilters(ledgerResources *ledgerResources) *filter.RuleSet
func createSystemChainFilters(ml *multiLedger, ledgerResources *ledgerResources) *filter.RuleSet
func (cs *chainSupport) start()
func (cs *chainSupport) NewSignatureHeader() (*cb.SignatureHeader, error)
func (cs *chainSupport) Sign(message []byte) ([]byte, error)
func (cs *chainSupport) Filters() *filter.RuleSet
func (cs *chainSupport) BlockCutter() blockcutter.Receiver
func (cs *chainSupport) Reader() ledger.Reader
func (cs *chainSupport) Enqueue(env *cb.Envelope) bool
func (cs *chainSupport) Errored() <-chan struct{}
//创建块,调取ledger.CreateNextBlock(cs.ledger, messages)
func (cs *chainSupport) CreateNextBlock(messages []*cb.Envelope) *cb.Block
func (cs *chainSupport) addBlockSignature(block *cb.Block)
func (cs *chainSupport) addLastConfigSignature(block *cb.Block)
//写入块
func (cs *chainSupport) WriteBlock(block *cb.Block, committers []filter.Committer, encodedMetadataValue []byte) *cb.Block
func (cs *chainSupport) Height() uint64
//代码在orderer/multichain/chainsupport.go
```
func (cs *chainSupport) WriteBlock(block *cb.Block, committers []filter.Committer, encodedMetadataValue []byte) *cb.Block 代码如下:
```go
func (cs *chainSupport) WriteBlock(block *cb.Block, committers []filter.Committer, encodedMetadataValue []byte) *cb.Block {
for _, committer := range committers {
committer.Commit()
}
cs.addBlockSignature(block)
cs.addLastConfigSignature(block)
err := cs.ledger.Append(block)//账本追加块
return block
}
//代码在orderer/multichain/chainsupport.go
```

网址:http://www.qukuailianxueyuan.io/

欲领取造币技术与全套虚拟机资料

区块链技术交流QQ群:756146052  备注:CSDN

尹成学院微信:备注:CSDN

网址:http://www.qukuailianxueyuan.io/

欲领取造币技术与全套虚拟机资料

区块链技术交流QQ群:756146052  备注:CSDN

尹成学院微信:备注:CSDN

Fabric 1.0源代码分析(29) Orderer #multichain(多链支持包)相关推荐

  1. Fabric 1.0源代码分析(27) Orderer #configupdate(处理通道配置更新)

    # Fabric 1.0源代码笔记 之 Orderer #configupdate(处理通道配置更新) ## 1.configupdate概述 configupdate,用于接收配置交易,并处理通道配 ...

  2. Fabric 1.0源代码分析(25) Orderer

    # Fabric 1.0源代码笔记 之 Orderer ## 1.Orderer概述 Orderer,为排序节点,对所有发往网络中的交易进行排序,将排序后的交易安排配置中的约定整理为块,之后提交给Co ...

  3. Fabric 1.0源代码分析(30) Orderer #BroadcastServer(Broadcast服务端)

    # Fabric 1.0源代码笔记 之 Orderer #BroadcastServer(Broadcast服务端) ## 1.BroadcastServer概述 BroadcastServer相关代 ...

  4. Fabric 1.0源代码分析(26)Orderer #ledger(Orderer Ledger)

    # Fabric 1.0源代码笔记 之 Orderer #ledger(Orderer Ledger) ## 1.Orderer Ledger概述 Orderer Ledger代码分布在orderer ...

  5. Fabric 1.0源代码分析(28) Orderer #localconfig(Orderer配置文件定义)

    # Fabric 1.0源代码笔记 之 Orderer #localconfig(Orderer配置文件定义) ## 1.配置文件定义 ```bash General: #通用配置 LedgerTyp ...

  6. Fabric 1.0源代码分析(32)Peer #peer根命令入口及加载子命令

    # Fabric 1.0源代码笔记 之 Peer #peer根命令入口及加载子命令 ## 1.加载环境变量配置和配置文件 Fabric支持通过环境变量对部分配置进行更新,如:CORE_LOGGING_ ...

  7. Fabric 1.0源代码分析(15)gossip(流言算法)

    # Fabric 1.0源代码笔记 之 gossip(流言算法) ## 1.gossip概述 gossip,翻译为流言蜚语,即为一种可最终达到一致的算法.最终一致的另外的含义就是,不保证同时达到一致. ...

  8. Fabric 1.0源代码分析(37) Peer #DeliverClient(Deliver客户端)

    # Fabric 1.0源代码笔记 之 Peer #DeliverClient(Deliver客户端) ## 1.DeliverClient概述 DeliverClient代码分布如下: * peer ...

  9. Fabric 1.0源代码分析(32) Peer #peer node start命令实现

    # Fabric 1.0源代码笔记 之 Peer #peer node start命令实现 ## 1.peer node加载子命令start和status peer node加载子命令start和st ...

最新文章

  1. 造成机器学习项目失败的7个原因
  2. 查看当前正在运行的python进程
  3. 详解vue 路由跳转四种方式 (带参数)
  4. ARM3级流水和5级流水为什么都是PC=PC+8
  5. css颜色rgba代码对照表_改善 CSS 的 10 个最佳实践
  6. php2018面试题20块,php最新面试题2018届毕业生专享
  7. localhost与127.0.0.1的概念和工作原理之不同
  8. 组件通信 eventtBus
  9. 鸿蒙系统和中标麒麟系统关系,操作系统有哪些 先有鸿蒙后有麒麟V10 为5G时代量身定做...
  10. 关于 “Makefile:3:***遗漏分隔符。停止 。”解决方法二
  11. 【ROS】ros入门21讲(上)
  12. 用python提取图片主要颜色_用Python提取图片主要颜色
  13. CentOS 7安装Teamviewer 12
  14. 物质的粒子应该是空心的
  15. GCC Link Time Optimization
  16. JUnit5 + JMockit 知识整理
  17. java log viewer,LogViewer - 方便的日志查看工具
  18. 利用VLMCSD部署本地KMS服务器(Windows + CentOS7)
  19. 慧荣SM2246EN主控如何进行RDT测试开卡
  20. nodejs和php性能,Nodejs 和PHP 性能测试结果

热门文章

  1. 单片机简谱音乐2(孤勇者)-连音与0调的音处理,一个音仅占一个字节(8bit)大小
  2. java的多态代码例子_java多态例子,java多态代码实例
  3. 大三那年在某宝8块钱买的.NET视频决定了我的职业生涯
  4. windows10电脑自带的录屏工具
  5. 《MySQL》MySQL教程
  6. xilinx PL测 DP 点屏 /接收(三)--TX
  7. 靠,嘉立创打板又降价
  8. 解决wine不能输入的问题
  9. 这款高性价比商用笔记本值得入手
  10. 语音分类入门案例: 英文数字音频分类