bitxhub源码总结:共识—执行—持久化过程

 没有学过go,粗略读了一下源码,理解错误之处请指正,谢谢!

node.go 的mint()挖块方法向通道commitC放入了经过共识的block

 bitxhub源码总结:共识—执行—持久化过程_第1张图片

feedhub.go 调用order.go方法,从commitC通道获取已经生成的block

 bitxhub源码总结:共识—执行—持久化过程_第2张图片

feedhub.go调用ExecuteBlock方法,进入执行模块,block为参数

bitxhub源码总结:共识—执行—持久化过程_第3张图片

executor.go 将block发送到管道blockC

bitxhub源码总结:共识—执行—持久化过程_第4张图片

executor.go 从blockC接收数据,调用handleExecuteEvent()

bitxhub源码总结:共识—执行—持久化过程_第5张图片

executor.go  handleExecuteEvent() 继续转交给processExecuteEvent() 处理

bitxhub源码总结:共识—执行—持久化过程_第6张图片

executor.go  processExecuteEvent() 真正开始处理,执行block

bitxhub源码总结:共识—执行—持久化过程_第7张图片

------区块已经生成,打印执行区块的时间------

bitxhub源码总结:共识—执行—持久化过程_第8张图片

------快处理结束时,将BlockData发送到持久化通道persistC------

bitxhub源码总结:共识—执行—持久化过程_第9张图片

executor.go persistData()从persistC获取数据,调用ledger.go中PersistBlockData()

bitxhub源码总结:共识—执行—持久化过程_第10张图片

ledger.go 真正持久化数据

bitxhub源码总结:共识—执行—持久化过程_第11张图片

bitxhub源码总结:共识—执行—持久化过程_第12张图片

你可能感兴趣的:(跨链_Bitxhub,区块链,go)