fabric:gossip协议

gossip协议主要是一个P2P的网络传输协议。fabric主要通过此协议来进行区块的同步。具体地,leaderpeer节点会从orderer把区块拿到,然后把区块同步到该组织的其它peer节点。anchor peer节点主要用来同步各组织间的信息。gossip通过不断地广播alive消息来判断哪些节点在线,这个信息用PKI ID和发送方的签名,来保证作恶节点冒充其它节点。这个机制大概过程是:ca用根证书来生成节点的子证书,只有CA对应的公钥才能解开,也就说这个自证书一定是是CA颁发的,其它节点时没法伪造的。接收节点通过CA的公钥解开获得发送节点的公钥,然后再和发送的签名作比较即可。

fabric gossip代码主要流程:

peer/node/start.go:InitGossipService

InitGossipServiceCustomDeliveryFactory

NewGossipComponent

NewGossipService

NewGossipService函数主要实现了gossip服务的资源, 发送gossipmessage。sate.go:NewGossipStateProvider,会accept msg, go s.listen()中会把gossipChan的内容取出,写入账本。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值