一文了解Lotus网络内消息运转流程
Filecoin区块链作为一个分布式系统,各个节点都会保有全网状态的一个副本,节点间的状态需要彼此进行同步,同步的方式就是发送和执行消息。
Filecoin中的消息来源有两种:一是节点自身发出、二是从P2P网络中同步其它节点发出的消息。
一、节点自身发送消息
各个节点都会有一个消息池MessagePool,消息一般会被先发送到消息池中,再经由P2P网络发送到相邻节点。以下方法可以向消息池中添加消息:MessagePool.Add , MessagePool.Push ,MessagePool.PushWithNonce。新建MessagePool会启动一个go协程,用以发送消息到P2P网络。
消息池会监控链头的变化
(Provider.SubscribeHeadChanges),
并在内部动态增删消息
(MessagePool.HeadChange)。
二、同步网络中消息
Filecoin网络中的其它节点都会监控网络信息,监控目前有两种形式:
1、监控“到来区块”:由函数
HandleIncomingBlocks完成
2、监控“到来消息”:由函数
HandleIncomingMessages完成
监控时,会先注册一个校验器Validator,当有新数据到来时会先执行Validator的Validate方法,
HandleIncomingBlocks
HandleIncomingMessages
分别注册了
BlockValidator
lotus/chain/sub/HandleIncomingMessages
目前sub.Han