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的内容取出,写入账本。