[发明专利]用于区块链系统的压力测试的方法、介质和控制装置有效
申请号: | 201910868276.4 | 申请日: | 2019-09-16 |
公开(公告)号: | CN110580206B | 公开(公告)日: | 2023-04-28 |
发明(设计)人: | 陈小云;庄伟铭 | 申请(专利权)人: | 上海保险交易所股份有限公司 |
主分类号: | G06F11/22 | 分类号: | G06F11/22 |
代理公司: | 中国贸促会专利商标事务所有限公司 11038 | 代理人: | 高欣 |
地址: | 200122 上海市浦东新区自*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 用于 区块 系统 压力 测试 方法 介质 控制 装置 | ||
1.一种用于区块链系统的压力测试的方法,包括:
在单个服务器上按照区块链的初始配置参数部署初始数量的记账节点模块、共识节点模块以及应用程序编程接口服务器APIServer模块;
经由APIServer模块基于合约对部署在单个服务器上的区块链进行多轮测试,其中,在每轮测试中并发地对一个记账节点模块进行测试,并且调整针对各轮测试的并发数直到该并发数使得记账节点模块、共识节点模块以及APIServer模块中的一个模块的系统资源使用率基本饱和为止,其中在所述多轮测试期间检测到当并发数增长到一定程度时记账节点模块、共识节点模块以及APIServer模块中的一个模块的系统资源使用率趋于稳定时,认为该模块的系统资源使用率基本饱和;和
基于所述一个模块的系统资源使用率基本饱和时各模块的系统资源使用率确定用于典型压力测试场景的记账节点模块数量与共识节点模块数量之间的比例,并基于在所述多轮测试中检测到的各模块对CPU的多核利用率确定各模块对服务器的占用关系,其中,
系统资源使用率包括CPU使用率或内存使用率,并且其中
用于典型压力测试场景的记账节点模块数量与共识节点模块数量之间的比例与所述一个模块的系统资源使用率基本饱和时记账节点模块的系统资源使用率与共识节点模块的系统资源使用率之间的比例相同;和
基于各模块对CPU的多核利用率,将能够充分利用CPU多核优势的模块确定为适于单独部署在一个服务器上,和将难以利用CPU多核优势的两个模块确定为适于部署在同一个服务器上。
2.如权利要求1所述的方法,所述方法还包括:
基于所确定的用于典型压力测试场景的记账节点模块数量与共识节点模块数量之间的比例以及各模块对服务器的占用关系在多个服务器上部署各个模块;
经由APIServer模块基于所述合约对部署在多个服务器上的区块链进行多轮并发测试,其中在每轮测试中并发地对多个记账节点模块进行测试并且并发地对同一记账节点模块进行测试,并且其中对于各轮并发测试的并发数不同;和
检测各轮并发测试下的每秒交易数TPS和/或各个服务器的系统资源使用率。
3.如权利要求1或2所述的方法,其中
区块链的所述配置参数至少包括日志级别、块大小、安全传输层协议的开启状态、共识算法、P2P算法、记账算法以及加密算法中的一个或多个,和
区块链的初始配置参数是随机选择的或预先确定的。
4.如权利要求1或2所述的方法,其中
对于记账节点模块、共识节点模块以及APIServer模块的初始数量分别为2个、1个以及1个。
5.如权利要求1或2所述的方法,其中
所述方法还包括对部署在单个服务器上的区块链调整其配置参数;
检测与不同的配置参数相对应的各模块的系统资源使用率和使记账节点模块、共识节点模块以及APIServer模块中的一个模块的系统资源使用率基本饱和的并发数;以及
将与最佳并发数相对应的配置参数确定为用于典型压力测试场景的配置参数,并且将与最佳并发数相对应的配置参数下的记账节点模块、共识节点模块和APIServer模块中的一个模块的系统资源使用率基本饱和时记账节点模块与共识节点模块之间的系统资源使用率的比例确定为用于典型压力测试场景的记账节点模块数量与共识节点模块数量之间的比例。
6.如权利要求1或2所述的方法,其中
所述合约使得在区块链上写入键-值对,其中,在各轮测试中并发的多个测试之间采用不同的键。
7.一种存储有计算机可执行指令的计算机可读介质,当所述计算机可执行指令被处理器执行时,使得所述处理器执行如权利要求1-6中任一项所述的方法。
8.一种用于区块链系统的压力测试的控制装置,所述控制装置包括存储有计算机可执行指令的存储器和处理器,当所述计算机可执行指令被所述处理器执行时,使得所述装置执行如权利要求1-6中任一项所述的方法。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海保险交易所股份有限公司,未经上海保险交易所股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910868276.4/1.html,转载请声明来源钻瓜专利网。
- 上一篇:能够进行多接口测试的系统
- 下一篇:基于QT框架的逻辑测试应用生成方法