如何提升区块链系统性能是很多开发者都会关注的事,但是有些对区块链并非十分熟悉的开发者可能会感到没有头绪。长安链提供了性能分析工具帮助开发者梳理系统耗时,优化系统性能。下面对长安链性能分析工具原理及使用进行介绍。
time_counter.sh是长安链性能分析工具,可用于分析TBFT共识下,一轮完整共识过程中各个阶段的耗时情况,帮助用户了解底链性能。采用此性能分析工具,需要确保txpool、core、consensus、storage模块开启INFO级别的日志。
图 1 一轮共识流程图
整体共识流程如上图所示,主要分为四个阶段,分别是Proposal, Prevote, Precommit, Commit,下面分别从共识主从节点视角介绍四个阶段的流程。
○ Proposal阶段:开始新一轮共识时,会选举出新的主节点,主节点的共识模块consensus会通知核心引擎模块core构造区块,共识模块收到新的区块后,将会构造提案并广播给其他的从节点,自己则进入到prevote阶段并广播prevote投票。
○ Proposal阶段:从节点的共识模块consensus收到主节点广播的提案后,将会通知自身的核心引擎模块core验证并执行区块,区块有效则进入到prevote阶段并广播自己的prevote投票。
○ Prevote阶段:主节点和从节点在prevote阶段收到2f+1张prevote投票后,将会进入到precommit阶段。
○ Precommit阶段:主节点和从节点进入到precommit阶段后,会构造并广播自己的到precommit投票,并将此时的共识状态写入wal中,确保重启时恢复到最新的共识状态,在收到2f+1张precommit投票后,将会进入到commit阶段。
○ Commit阶段:主节点和从节点进入到commit阶段后,会通知自身的核心引擎模块core提交区块,core调用存储模块将区块写入数据库,并通知共识模块进入下一高度区块的共识流程。
此部分细化了上述整体流程中各个阶段的具体操作,性能分析工具会根据关键日志检索出各具体操作的耗时情况。
(1)主节点core模块构造区块和执行交易GenBlock
○ fetch: 交易池检索一批交易用于构造区块;
○ prune:交易池调用存储模块进行增量防重;
○ cache:在区块剪裁模式下,交易池会缓存fetch的交易,以便从节点缺失这些交易时,可向主节点请求。
○ filter:布谷鸟对txId进行格式和时间校验;
○ begin DB transaction:采用sql存储时,开启一个事务;
○ new snapshot:执行交易前,创建snapshot,作为这个区块执行时的快照;
○ vm:交易并行调度执行和DAG构建;
○ finalize block: 计算区块头中交易默克尔树根、读写集树根、DAG树根;
(2)主节点consensus模块构造提案GenProposal
○ signBlock: 计算区块哈希值和对区块签名;
○ signProposal: 对提案进行签名;
(3)从节点consensus模块验证提案ProcProposal
○ verify:验证主节点身份和验证提案签名;
(4)从节点core模块验证区块和执行交易VerifyBlock
○ blockSign: 验证区块签名;
○ vm: 按DAG顺序执行交易;
○ txVerify:core模块从交易池取出区块中交易和验证交易(对于区块中在交易池的交易只需比对交易哈希是否一致;对于区块中不在交易池中的交易会进行交易格式、权限、时间戳及防重检查);
○ txRoot:计算并校验三颗树根是否有效;
○ pool:区块剪裁模式下,对区块进行恢复;
○ consensusCheckUsed: 对于同步过来的区块,验证区块中QC是否有效;
(5)从节点Prevote阶段
○ 从节点prevote阶段主要操作包括构造自身的prevote投票并对收到的2f+1张prevote投票进行验签,及投票的网络广播
(6)主从节点Precommit阶段
○ 主从节点precommit阶段主要操作包括构造自身的precommit投票并对收到的2f+1张precommit投票进行验签,及投票的网络广播;
○ 共识状态写入wal文件:marshalData和marshalEntry为序列化共识状态操作,saveWal为将序列化结果写入wal文件;
(7)主从节点提交区块CommitBlock
○ check: core模块验证区块高度和区块前置哈希是否合法;
○ marshal:DB模块对区块和交易读写集进行序列化;
○ writeFile:DB模块序列化结果写入wal文件;
○ writeCache:DB模块对区块信息写缓存;
○ writeBatchChan:DB模块将区块信息放入顺序写channel;(快速写模式)
○ writeKvDB:DB模块将区块信息写入数据库;(普通写模式)
○ ss:清除snapshot;
○ conf:如果是配置交易则进行配置变更;
○ pool:交易池删除该区块中的交易并将旁枝区块中的交易重新放回交易池;
○ pubConEvent:对区块中交易事件进行通知;
○ filter:将区块中交易加入到布谷鸟过滤器;
○ other:添加监控记录;
(8)其他操作
○ 主要是模块间通过msgbus交互的操作、主节点广播proposal到从节点接受proposal间的网络传递等过程;
○ 还有部分操作,底链关键日志中并未进行记录;
2、分析结果
图 2 各阶段各具体操作耗时分析结果
一轮共识流程整体耗时:
core_commit_interval = (1)主节点core模块GenBlock时间 + (2)主节点consensus模块GenProposal时间 + (3)从节点consensus模块ProcProposal时间 + (4)从节点core模块VerifyBlock时间 + (5)从节点prevote阶段耗时 + (6)主从节点precommit阶段耗时 + (7)主从节点core模块CommitBlock时间 + (8) 其他操作时间
重叠时间说明:
○ txpool_total 是主节点交易池中fetch、prune、cache三部分时间的加和;
○ core_gen_fetch 即交易池txpool_total的时间,core模块也进行了记录;
○ core_gen_total 是主节点core模块构造区块的整体时间;
○ consensus_total 是主节点consensus模块对区块签名和构造提案的时间;
○ consensus_proposal 是主节点proposal阶段整体耗时,包括了core模块构造区块和consensus模块构造提案的时间;
○ core_verify_total 是从节点core模块验证区块和执行交易的总时间;
○ storage_total 是存储写区块和读写集等信息的总时间;
○ core_commit_db 即存储模块storage_total的时间,core模块也进行了记录;
○ core_commit_total 是core模块提交区块的总时间;
○ core_commit_interval 是此区块的一轮共识总时间;
文档链接:https://docs.chainmaker.org.cn/v2.3.1/html/dev/性能分析工具.html