Hyperledger Fabric 排序节点启动过程

本文详细解析了Hyperledger Fabric Orderer节点的启动过程,包括配置加载、日志级别设置、MSP初始化,以及核心的gRPC服务结构初始化和启动。在gRPC服务结构初始化中,重点讨论了Registrar结构的创建,它管理账本和共识过程,尤其是Kafka共识的启动。gRPC服务启动则涉及gRPC服务结构的绑定和监听。内容源自《区块链原理、设计与应用》一书,关注金融科技领域的读者不容错过。
摘要由CSDN通过智能技术生成

Hyperledger 源码分析之 Fabric

Orderer 节点启动通过 orderer 包下的 main() 方法实现,会进一步调用到 orderer/common/server 包中的 Main() 方法。

核心代码如下所示。

// Main is the entry point of orderer processfunc Main() {
  
    fullCmd := kingpin.MustParse(app.Parse(os.Args[1:]))

    // "version" command
    if fullCmd == version.FullCommand() {
  
        fmt.Println(metadata.GetVersionInfo())
        return
    }

    conf := config.Load()
    initializeLoggingLevel(conf)
    initializeLocalMsp(conf)

    Start(fullCmd, conf)}

包括配置初始化过程和核心启动过程两个部分:

  • config.Load():从本地配置文件和环境变量中读取配置信息,构建配置树结构。

  • initializeLoggingLevel(conf):配置日志级别。

  • initializeLocalMsp(conf):配置 MSP 结构。

  • Start():完成启动后的核心工作。

整体过程

核心启动过程都在 orderer/common/server包中的 Start() 方法,如下图所示。


Start() 方法会初始化 gRPC 服务需要的结构,然后启动服务。

核心代码如下所示。

func Start(cmd string, conf *config.TopLevel) {
  
    logger.Debugf("Start()")
    signer := localmsp.NewSigner()
    manager := initializeMultichannelRegistrar(conf, signer)
    server := NewServer(manager, signer, &conf.Debug)

    switch cmd {
  
    case start.FullCommand(): // "start" command
        logger.Infof(
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值