一文了解Lotus网络内消息运转流程

本文详细解析了Filecoin Lotus网络中消息的流转过程,包括节点如何发送和同步消息,消息池的工作原理,以及区块和消息的验证与执行机制。节点通过MessagePool管理消息,监听链头变化,并通过P2P网络同步其他节点的消息。区块中的消息经过验证后执行,矿工在打包区块时选择消息执行,最终通过虚拟机完成消息的执行。
摘要由CSDN通过智能技术生成

一文了解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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值