区块链教程Fabric1.0源代码分析Orderer localconfig

简介:

  兄弟连区块链教程Fabric1.0源代码分析Orderer localconfig,2018年下半年,区块链行业正逐渐褪去发展之初的浮躁、回归理性,表面上看相关人才需求与身价似乎正在回落。但事实上,正是初期泡沫的渐退,让人们更多的关注点放在了区块链真正的技术之上。

Fabric 1.0源代码笔记 之 Orderer #localconfig(Orderer配置文件定义)

1、配置文件定义

General: #通用配置
    LedgerType: file #账本类型,包括ram、json和file,其中ram保存在内存中,生产环境推荐使用file
    ListenAddress: 127.0.0.1 #服务绑定的监听地址
    ListenPort: 7050 #服务绑定的监听端口
    TLS: #启用TLS时的相关配置
        Enabled: false #是否启用TLS
        PrivateKey: tls/server.key #Orderer签名私钥
        Certificate: tls/server.crt #Orderer身份证书
        RootCAs: #信任的根证书
          - tls/ca.crt
        ClientAuthEnabled: false #是否对客户端也进行认证
        ClientRootCAs:
    LogLevel: info #日志级别
    LogFormat: '%{color}%{time:2006-01-02 15:04:05.000 MST} [%{module}] %{shortfunc} -> %{level:.4s} %{id:03x}%{color:reset} %{message}'
    GenesisMethod: provisional #初始区块的提供方式,支持provisional或file,前者基于GenesisProfile指定的configtx.yaml中Profile生成,后者基于指定的初始区块文件
    GenesisProfile: SampleInsecureSolo #provisional方式生成初始区块时采用的Profile
    GenesisFile: genesisblock #使用现成的初始区块文件时,文件的路径
    LocalMSPDir: msp #本地msp文件的路径
    LocalMSPID: DEFAULT #MSP的ID
    Profile: #是否启用go profiling
        Enabled: false
        Address: 0.0.0.0:6060
    BCCSP: #密码库机制等,可以为SW(软件实现)或PKCS11(硬件安全模块)
        Default: SW
        SW:
            Hash: SHA2 #哈希算法类型
            Security: 256
            FileKeyStore: #本地私钥文件路径,默认指向<mspConfigPath>/keystore
                KeyStore:
FileLedger: #基于文件的账本的配置
    Location: /var/hyperledger/production/orderer #存放区块文件的位置,一般为/var/hyperledger/production/orderer/目录
    Prefix: hyperledger-fabric-ordererledger #如果不指定Location,则在临时目录下创建账本时使用的目录名称
RAMLedger: #基于内存的账本最多保留的区块个数
    HistorySize: 1000
Kafka: #Orderer使用Kafka集群作为后端时,Kafka的配置
    Retry: #Kafka未就绪时Orderer的重试配置,orderer会利用sarama客户端为channel创建一个producer、一个consumer,分别向Kafka写和读数据
        ShortInterval: 5s #操作失败后的快速重试阶段的间隔
        ShortTotal: 10m #快速重试阶段最多重试多长时间
        LongInterval: 5m #快速重试阶段仍然失败后进入慢重试阶段,慢重试阶段的时间间隔
        LongTotal: 12h #慢重试阶段最多重试多长时间
        NetworkTimeouts: #sarama网络超时时间
            DialTimeout: 10s
            ReadTimeout: 10s
            WriteTimeout: 10s
        Metadata: #Kafka集群leader选举中的metadata请求参数
            RetryBackoff: 250ms
            RetryMax: 3
        Producer: #发送消息到Kafka集群的超时
            RetryBackoff: 100ms
            RetryMax: 3
        Consumer: #从Kafka集群读取消息的超时
            RetryBackoff: 2s
    Verbose: false #是否开启Kafka客户端的调试日志
    TLS: #Kafka集群的连接启用TLS时的相关配置
      Enabled: false #是否启用TLS,默认不开启
      PrivateKey: #Orderer证明身份用的签名私钥
      Certificate: #Kafka身份证书
      RootCAs: #验证Kafka证书时的CA证书
    Version: #Kafka版本号
#代码在/etc/hyperledger/fabric/orderer.yaml

2、TopLevel结构体定义

type TopLevel struct {
    General    General
    FileLedger FileLedger
    RAMLedger  RAMLedger
    Kafka      Kafka
}

type General struct {
    LedgerType     string
    ListenAddress  string
    ListenPort     uint16
    TLS            TLS
    GenesisMethod  string
    GenesisProfile string
    GenesisFile    string
    Profile        Profile
    LogLevel       string
    LogFormat      string
    LocalMSPDir    string
    LocalMSPID     string
    BCCSP          *bccsp.FactoryOpts
}

type TLS struct {
    Enabled           bool
    PrivateKey        string
    Certificate       string
    RootCAs           []string
    ClientAuthEnabled bool
    ClientRootCAs     []string
}

type Profile struct {
    Enabled bool
    Address string
}

type FileLedger struct {
    Location string
    Prefix   string
}

type RAMLedger struct {
    HistorySize uint
}

type Kafka struct {
    Retry   Retry
    Verbose bool
    Version sarama.KafkaVersion
    TLS     TLS
}

type Retry struct {
    ShortInterval   time.Duration
    ShortTotal      time.Duration
    LongInterval    time.Duration
    LongTotal       time.Duration
    NetworkTimeouts NetworkTimeouts
    Metadata        Metadata
    Producer        Producer
    Consumer        Consumer
}

type NetworkTimeouts struct {
    DialTimeout  time.Duration
    ReadTimeout  time.Duration
    WriteTimeout time.Duration
}

type Metadata struct {
    RetryMax     int
    RetryBackoff time.Duration
}

type Producer struct {
    RetryMax     int
    RetryBackoff time.Duration
}

type Consumer struct {
    RetryBackoff time.Duration
}
//代码在orderer/localconfig/config.go
相关文章
|
2月前
|
存储 供应链 监控
区块链技术在供应链管理中的应用与前景分析
随着信息化时代的到来,供应链管理面临着越来越多的挑战和机遇。本文主要探讨了区块链技术在供应链管理中的应用,以及未来的发展前景。通过对区块链技术的特点和优势进行分析,结合实际案例和趋势展望,展示了区块链技术在提升供应链透明度、效率和安全性方面的潜力,以及未来发展的可能方向。
|
2月前
|
安全 区块链
区块链积分商城系统开发详细指南//需求功能/指南教程/源码流程
Developing a blockchain points mall system involves multiple aspects such as blockchain technology, smart contracts, front-end development, and business logic design. The following is the general process for developing a blockchain points mall system
|
2月前
|
存储 算法 API
面向企业的区块链教程(一)(2)
面向企业的区块链教程(一)
61 6
|
19天前
|
存储 安全 区块链
元宇宙与区块链技术的关系可以从多个角度进行阐述。以下是对这两者之间关系的详细分析
**元宇宙:虚拟世界融合现实元素,强调交互与沉浸;区块链:去中心化、安全的分布式账本。两者结合,区块链确保元宇宙中虚拟资产安全、支付高效、身份验证私密、治理透明,支撑其经济体系与用户信任,驱动未来发展。**
|
2月前
|
存储 供应链 安全
基于区块链技术的智能合约安全性分析
【5月更文挑战第31天】本文深入探讨了区块链技术中智能合约的安全性问题,通过分析现有智能合约的安全漏洞和攻击手段,提出了一系列增强智能合约安全性的策略。文章首先介绍了区块链和智能合约的基本概念,随后详细讨论了智能合约面临的安全挑战,包括代码漏洞、重入攻击等问题,并对比分析了不同平台下智能合约的安全性差异。最后,文章提出了一系列提高智能合约安全性的建议,旨在为区块链应用的健康发展提供参考。
|
26天前
|
区块链
近期区块链市场趋势分析
**区块链市场趋势摘要:** - 跨链技术成熟,提升互操作性,助力区块链网络融合。 - DeFi持续繁荣,智能合约与AMM创新活跃,市场竞争驱动市场壮大。 - NFT市场多样化,拓展至游戏、音乐等领域,实用性增强。 - 区块链寻求绿色转型,通过PoS共识与绿色能源减少能耗。 - 技术模块化、可组合性提升,降低成本,增强系统灵活性。 这些趋势展现区块链潜力,带来机遇与挑战,促进行业创新。
|
2月前
|
存储 算法 安全
区块链系统开发技术规则分析
区块链核心技术包括:1) 哈希算法,利用单向函数将任意数据转化为固定长度代码,确保安全验证;2) 非对称加密,使用公钥和私钥一对进行加密解密,保证信息安全;3) 共识机制,如PoW、PoS、DPoS等,实现快速交易验证和确认;4) 智能合约,自动执行的可信代码,一旦编写即不可更改,用于自动化交易;5) 分布式存储,将数据分散存储在网络各处,涵盖结构化、非结构化和半结构化数据。
|
2月前
|
供应链 区块链 数据安全/隐私保护
探索区块链技术在金融领域的应用与前景分析
本文将深入探讨区块链技术在金融领域的具体应用场景,分析其优势与挑战,并展望未来发展趋势。通过案例分析和技术解析,揭示区块链技术在金融行业中的革新意义及前景。
307 15
|
2月前
|
安全 区块链
区块链游戏系统开发步骤需求丨功能逻辑丨规则玩法丨指南教程丨源码详细
Developing blockchain game systems has been a highly anticipated field in recent years. By combining blockchain technology and game mechanics, players can enjoy a brand new gaming experience and higher game credibility.
|
12月前
Minecraft Fabric 教程 #8 添加附魔书
这就创建了一个FireBoom附魔书 onTargetDamaged //当目标被攻击 在mc FireballEntity类有一个 方法就是当火球碰撞了就创建一个火焰爆炸的效果
53 0

热门文章

最新文章