FISCO-BCOS源码各模块的简单理解

原创内容,未经允许不得转载

本文对源码的解读为个人理解,欢迎指正
关联github仓库:FISCO-BCOS
内容太多了,慢慢深入阅读,持续更新中...(2020-04-30)

各模块的功能:

可以简单分EVM模块、账本模块、共识同步模块、网络模块

EVM模块:执行交易

  • libethcore
    • block区块定义
    • transaction定义
    • abi定义
    • 并行交易定义
  • libevm
    • EVMC 提供exec接口
    • ExtVmFace 提供evm的call get接口
    • VMFactory
  • libinterpreter EVM的实现
    • VM 虚拟机汇编操作的定义
    • VMCall call操作对应汇编的定义
    • VMOpt copyCode, exp256 操作工具类
  • libexecutive 执行交易
    • Executive: call, create,execute
    • ExtVM: 生成调用结果或部署结果
  • libtxpool 交易池,待确认的交易
    • TransactionNonceCheck commonTxCheck
    • TxPool insert, clear, pending, verify等对交易池的操作

账本模块:

  • libstorage 用不同db存储的数据层
    • RocksDBStorage, BasicRocksDB: 基本put commit等操作
    • LevelDBStorage: commit, select, setDb..基本put commit等操作
    • SQLStorage: 是否与AMDB相关
    • ZdbStorage: 在mysql上,创建预编译、系统表等数据表
    • CachedStorage: 缓存存储,具体未知
    • ScalableStorage: 可扩展存储,与AMDB proxy相关?
    • MemoryTable 系统表,如权限控制,crud等
    • BinLog: binlog handler(decode, encode, ), binlog storage
    • SQLBasicAccess: buildSQL, buildConditions
    • SQLConnectionPool: 连接池
    • Table: table的基本操作setEntries
  • libstoragestate MPT存储
    • StorageState MPT操作 定义对state的操作如,createAccount,createContract,rollback, addBalance
    • StorageStateFactory 工厂类
  • libledger 数据层上的账本层
    • DBInitializer: 初始化storage相关,create实例
    • Ledger, LedgerParam:
      • 创建consensusEngine, createRaftSealer, createPBFTSealer, initPBFTEngine
      • 初始化blockVerifier, eventLogFilter, initBlockChain, initSync, initTxPool, initSync
    • LedgerManager: getGroupListForRpc (.h中获取BlockChainInterface等face接口)
  • libmptstate ethereum原生代码
    • Account 账户的定义,nonce, code, balance等, setCode账户代码
    • State, MPTState MPTStateFactory
      • MPTStateFactory: getState
      • State: addAddress, addBalance/subBalance, createAccount, codeHash, addresHash
      • MPTState: commit操作,维持MPT State状态树,State为数据层的话,MPTState为接口层

共识同步模块 共识时verifier用到到账本模块,用到evm执行

  • libconsensus
    • Sealer 定义sealer操作(打包区块), loadTxs, reportNewBlock, isBlockSyncing
    • ConsensusEngineBase: 区块校验、
    • pbft待详读 PBFT分组共识算法、HotStuff共识算法
    • raft待详读
    • rotating_pbft(RPBFT) 待详读 基于pbft的DPOS
  • libblockverifier
    • BlockVerifier
      • executeBlock
      • executeTransaction
      • parallelExecuteBlock
    • DAG, TxDAG 用于并行交易
    • ExecutiveContext 执行交易的上下文
  • libblockchain
    • BlockChainImp 区块链逻辑的实现,检查构建创世块、获取区块和交易等face接口的实现
  • libsync
    • DownloadingBlockQueue, DownloadingTxsQueue 与RLP结合
    • GossipBlockStatus 传递区块状态包
    • DownloadRequest, RspBlockReq 下载区块请求
    • SyncMaster 同步操作定义,send,broadcast
    • SyncTransaction 广播交易
    • SyncMsgEngine msg监听、收发
      • SyncMsgPacket 广播的消息包
    • SyncTreeTopology 网络拓扑图 nodeList, nodeInfo

与网络模块

  • libnetwork
    • ASIOInterface boost的网络模块,用于socket连接, ssl的websocket连接
    • Host: 节点间握手(Server/Client) 与P2P关联
      • handshakeServer ssl
      • asyncConnect..
    • Session session会话,监听信息
    • PeerWhitelist 白名单
  • libp2p
    • Service
      • heartBeat 与updateStaticNodes保持连接
      • asyncSendMessageByNodeID, 或broadcast, multicast
      • onMessage, onConnect等
    • P2PSession
      • heartBeat心跳包
      • onTopicMessage等监听topic信息
    • message: P2PMessage P2PMessageRC2
    • StatisticHandler block/tx sync的设置,如updateDownloadedTxsCount
  • librpc
    • SafeHttpServer 接收/回复rpc API的请求
    • Rpc 定义rpc的接口
    • JsonHelper HttpMessage等解析工具类
  • libchannelserver 基于channel的sdk长连接协议定义,与web3sdk中定义类似,此处为server, sdk为client,可参考另一篇sdk的文章

加密、鉴权模块

  • libdevcrypto:AES(CBC模式), Hash(md, keccak.sha256, secp256k1)
    • gm 国密sm2, sm3, sm4, 国密hash, aes等
  • libsecurity 落盘加密
    • EncryptedLevelDB leveldb文件加密
    • EncryptedFile: decryptContents解密文件
    • KeyCenter: KeyCenterHttpClient keyServer密钥管理中心

特性模块:

  • libprecompiled 预编译合约的实现,包含接口solidity文件。与table直接交互
  • libeventfilter event日志的过滤器
    • EventLogFilterManager
    • EventLogFilterParams
    • EventLogFilter: matches
  • libdevcore 地址, base64, log, rlp, trie等定义
  • libconfig 全局配置 Global configure of the node
  • tools shell脚本,build_chain, get_node_certs等
  • test 测试类

libinitializer

读取配置文件,进行初始化,包含:

  • Initializer,总的初始化,将P2P, RPC, Secure, Ledger, Log等模块的初始化集中处理。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350