Hyperledger Fabric Orderer 配置解析

发布时间:2024年01月09日

文中使用的 fabric 版本为 2.4.1

排序节点在 Fabric 网络中为 Peer 提供排序服务。与 Peer 节点类似,排序节点支持从命令行参数、环境变量或配置文件中读取配置信息。环境变量中配置需要以 ORDERER_前缀开头,例如,配置文件中的 general.ListenAddress 项,对应到环境变量 ORDERER_GENERAL_LISTENADDRESS。

排序节点默认的配置文件读取路径为 $FABRIC_CFG_PATH 中定义的路径;如果没找到,则尝试查找当前目录;如果还没有找到,则尝试查找默认的 /etc/hyperledger/fabric 路径。

在结构上,orderer.yaml 文件中一般包括 GeneralFileLedgerRAMLedgerKafkaDebugOperationsMetricsConsensus 八大部分.


General 部分

这一部分主要是一些通用配置,如账本类型、服务信息、配置路径等。这些配置影响到服务的主要功能,十分重要.

配置项作用默认值
ListenAddress服务绑定的监听地址,一般需要指定为所服务的特定网络接口的地址或全网(0.0.0.0)127.0.0.1
ListenPort服务绑定的监听端口7050
TLS.Enabled启用 TLS 时的相关配置false
TLS.PrivateKeyOrderer 签名私钥tls/server.key
TLS.CertificateOrderer 身份证书tls/server.crt
TLS.RootCAs信任的根证书tls/ca.crt
TLS.ClientAuthRequired是否对客户端也进行认证false
TLS.ClientRootCAs信任的客户端根证书列表N/A
Keepalive.ServerMinInterval允许其他客户端 ping 消息的最小间隔,超时则断开连接60s
Keepalive.ServerInterval到客户端的 ping 消息的间隔7200s
Keepalive.ServerTimeout关闭连接前等待响应的时间20s
MaxRecvMsgSizeGRPC 服务器和客户端可以接收的最大消息大小 (以字节为单位)104857600
MaxSendMsgSizeGRPC 服务器和客户端可以发送的最大消息大小 (以字节为单位)104857600
Clusterraft 模式下的集群配置N/A
Cluster.SendBufferSize发送缓冲区的最大长度10
Cluster.ClientCertificate双向 TLS 认证时,作为客户端证书的文件路径,如果没设置会使用 TLS.CertificateN/A
Cluster.ClientPrivateKey双向 TLS 认证时,作为客户端私钥的文件路径,如果没设置会使用 TLS.PrivateKeyN/A
Cluster.ListenPort监听端口默认使用 gRPC 相同的端口N/A
Cluster.ListenAddress监听地址默认使用 gRPC 相同的地址N/A
Cluster.ServerCertificate双向 TLS 认证时,作为服务端证书的文件路径N/A
Cluster.ServerPrivateKey双向 TLS 认证时,作为服务端私钥的文件路径N/A
BootstrapMethod获取引导块的方法,2.x 版本中仅支持 file 或 nonefile
BootstrapFile系统通道初始区块或最新配置区块文件路径N/A
LocalMSPDir本地 MSP 文件路径msp
LocalMSPIDMSP IDSampleOrg
Profile是否启用 Go profiling , 开启会影响性能N/A
BCCSP密码库机制等,可以为 SW(软件实现)或 PKCS11 (硬件安全模块)SW
Authentication.TimeWindow如果客户端和服务端时钟差异超过窗口指定值,则拒绝消息15m

FileLedger 部分

配置项作用默认值
Location指定存放区块文件的位置,一般为 /var/hyperledger/production/orderer。该目录下面包括 chains 子目录,存放各个 chain 的区块;index 目录,存放索引文件/var/hyperledger/production/orderer

Kafka 部分

因为不推荐使用了,暂时不关注


Debug 部分

Debug 部分主要用于对排序节点进行调试和差错时的追踪配置。

配置项作用默认值
BroadcastTraceDir广播请求的追踪路径N/A
DeliverTraceDir交付请求的追踪路径N/A

Operations 部分

Operations 部分与 Peer 相关配置类似,主要设置运行时对外的 RESTful 管理服务,包括监听的地址和 TLS 安全配置.

配置项作用默认值
ListenAddressRESTful 管理服务的监听地址127.0.0.1:8443
TLS.Enabled是否启用 TLS 保护false
TLS.Certificate服务端使用证书文件路径N/A
TLS.PrivateKey服务端使用私钥文件路径N/A
TLS.ClientAuthRequired是否开启客户端验证以限定访问的客户端,默认关闭,推荐开启false
TLS.ClientRootCAs开启客户端验证时,信任的客户端根证书路径列表[]

Metrics 部分

Metrics 部分与 Peer 相关配置类似,负责配置统计服务

配置项作用默认值
provider统计服务类型,可以为 statsd (推送模式),prometheus (拉取模式),disableddisabled
statsd.network网络协议类型,tcp 或 udpudp
statsd.address修改为外部 statsd 的服务地址127.0.0.1:8125
statsd.writeInterval推送统计汇报到 statsd 的时间间隔10s
statsd.prefix为所有统计推送添加前缀N/A

注意 statsdprometheus 都是流行的开源监控数据收集软件。


Consensus 部分

共识为 Raft 模式时的日志存储配置

配置项作用默认值
WALDir预写日志的存储位置,每个通道独占一个同名的子目录/var/hyperledger/production/orderer/etcdraft/wal
SnapDir快照文件的存储位置,每个通道独占一个同名的子目录/var/hyperledger/production/orderer/etcdraft/snapshot
EvictionSuspicion节点怀疑被从通道移除,触发从其他节点获取区块来确认的等待时间。隐藏参数10m

statsdhyperledgerfabricgrpc

? 著作权归作者所有

文章来源:https://blog.csdn.net/y19910825/article/details/135468881
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。