一种多种业务请求并发性的测试方法及装置与流程

文档序号:16061430发布日期:2018-11-24 12:13阅读:212来源:国知局

本申请涉及计算机技术领域,尤其涉及一种多种业务请求并发性的测试方法及装置。

背景技术

网络传输中的数据传输具有高带宽、低延迟的特性。为了防止传输中产生带宽、丢包、延迟等异常情况,需要对数据传输性能进行测试,即测试数据传输中带宽、丢包、延迟等异常情况出现概率。

现有网络传输中数据传输的性能测试可以采用远程直接数据存取(remotedirectmemoryaccess,rdma)技术。在使用rdma性能测试中,一般使用mellanox驱动搭建跨语言的通讯协议(messagepassinginterface,mpi)业务平台,每次测试均进行单线程、单用户、满带宽的测试标准。

然而,对于多用户多业务的测试,则需要增加额外的客户端及服务器的数量,但不能实现多用户的并发性测试,即当前的方案需要消耗更多服务器,同时缺少并发性测试,导致多用户多业务并发数据传输过程中带宽、延迟、丢包异常情况无法查看,无法真实度量出来实际测试效果。其中,并发性是指两个或多个事件在同一时间间隔内发生。



技术实现要素:

本申请实施例提供一种多种业务请求并发性的测试方法及装置,用于实现对多种业务请求并发性的数据传输测试。

第一方面,提供了一种多种业务请求并发性的测试方法,该方法可以包括:

基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,其中,所述第三矩阵包括第一数量的第四矩阵,每个所述第四矩阵是由一个线程处理得到的,所述线程用于处理一种业务请求,所述第一矩阵与所述第二矩阵的行数和列数均大于预设阈值;

获取第一数量的第四矩阵中每个所述第四矩阵所属线程对应的源端口;

基于每个所述第四矩阵与其对应的源端口,获取所述每个第四矩阵对应的业务请求和该源端口对应的用户;

根据所述第一数量的第四矩阵对应的业务请求和所述源端口对应的用户,生成多种业务请求并发性测试的测试报告,测试报告包括并发性测试的第一数量的业务请求和第一数量的业务请求对应的用户数量,以实现第一数量的业务请求的并发性测试。

在一个可选的实现中,基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵之前,该方法还包括:

启动第一数量的线程,所述第一数量的第四矩阵是所述第一数量的线程将预设的第一矩阵与第二矩阵采用矩阵乘法算法得到的。

在一个可选的实现中,基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,所述第三矩阵包括第一数量的第四矩阵,包括:

分别对所述第一矩阵与所述第二矩阵采用均分矩阵算法,得到所述第一矩阵的所述第一数量的分矩阵和所述第二矩阵的第一数量的分矩阵;

调用所述第一数量的线程分别将所述第一矩阵中每行分矩阵与所述第二矩阵中每列分矩阵相乘,得到所述第一数量的第四矩阵。

在一个可选的实现中,获取第一数量的第四矩阵中每个第四矩阵所属线程对应的端口信息,包括:

采用矩阵求和算法对各个线程上的第四矩阵进行聚合,基于所述各个线程间的通信,获取第一数量的第四矩阵中每个所述第四矩阵所属线程对应的源端口。

在一个可选的实现中,多种业务请求并发性测试的测试报告还包括测试开始时间;

生成多种业务请求并发性测试的测试报告之前,该方法还可以包括:

获取第三矩阵的生成时间;

基于该第三矩阵的生成时间和测试开始时间,采用时间差值运算,获取多种业务请求并发性测试的运行时间。

第二方面,提供了一种测试装置,该装置可以包括:运算单元、获取单元和生成单元;

所述运算单元,用于基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,其中,第三矩阵包括第一数量的第四矩阵,每个第四矩阵表示每种业务请求,每种业务请求由一个线程处理,线程用于处理一种业务请求,第一矩阵与第二矩阵的行数和列数均大于预设阈值;

所述获取单元,用于获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口;基于每个所述第四矩阵与其对应的源端口,获取所述每个第四矩阵对应的业务请求和该源端口对应的用户;

所述生成单元,用于根据所述第一数量的第四矩阵对应的业务请求和所述源端口对应的用户,生成多种业务请求并发性测试的测试报告,所述测试报告包括并发性测试的第一数量的业务请求和第一数量的业务请求对应的用户数量。

在一个可选的实现中,该装置还包括启动单元;

所述启动单元,用于在所述运算单元基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵之前,启动第一数量的线程,所述第一数量的第四矩阵是所述第一数量的线程将预设的第一矩阵与第二矩阵采用矩阵乘法算法得到的。

在一个可选的实现中,所述运算单元,具体用于分别对第一矩阵与所述第二矩阵采用均分矩阵算法,得到第一矩阵的第一数量的分矩阵和第二矩阵的第一数量的分矩阵;调用第一数量的线程分别将第一矩阵中每行分矩阵与第二矩阵中每列分矩阵相乘,得到第一数量的第四矩阵。

在一个可选的实现中,获取单元,具体用于采用矩阵求和算法对各个线程上的第四矩阵进行聚合,基于各个线程间的通信,获取第一数量的第四矩阵中每个所述第四矩阵所属线程对应的源端口。

在一个可选的实现中,所述多种业务请求并发性测试的测试报告还包括测试开始时间;

所述获取单元,还具体用于获取第三矩阵的生成时间;

基于第三矩阵的生成时间和所述测试开始时间,采用时间差值运算,获取多种业务请求并发性测试的运行时间。

第三方面,提供了一种电子设备,该电子设备包括处理器、通信接口、存储器和通信总线,其中,处理器,通信接口,存储器通过通信总线完成相互间的通信;

存储器,用于存放计算机程序;

处理器,用于执行存储器上所存放的程序时,实现上述第一方面中任一所述的方法步骤。

第四方面,提供了一种计算机可读存储介质,该计算机可读存储介质内存储有计算机程序,所述计算机程序被处理器执行时实现上述第一方面中任一所述的方法步骤。

该技术方案为基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,第三矩阵包括第一数量的第四矩阵,其中,每个第四矩阵是由一个线程处理得到的,第一矩阵与第二矩阵的行数和列数均大于预设阈值;获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口;基于第四矩阵与源端口,获取每个第四矩阵对应的业务请求和每个源端口对应的用户,之后根据第一数量的第四矩阵对应的业务请求和源端口对应的用户,生成多种业务请求并发性测试的测试报告,测试报告包括并发性测试的第一数量的业务请求和第一数量的业务请求对应的用户数量,该测试方法解决了当前无法仿真多用户的多种业务请求测试,以及无法对多种业务请求并发性测试的问题。

附图说明

图1为本发明实施例提供的一种多种业务请求并发性测试方法的流程示意图;

图2为本发明实施例提供的一种测试装置的结构示意图;

图3为本发明实施例提供的一种电子设备的结构示意图。

具体实施方式

下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅是本申请一部分实施例,并不是全部的实施例。基于本申请实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。

本发明实施例提供的多种业务请求并发性的测试方法应用在服务器的rdma协议下的数据传输过程中。为了保证测试结果的准确性,服务器需要具有较强计算能力。

该服务器可以提供该测试方法测试平台和测试环境。该测试方法的测试平台要求服务器安装mellanox网卡适配器,如ex(vpi,ib,en)(firmware:fw-connectx5)、(vpi,ib,en)(firmware:fw-connectx5)或lx(en)(firmware:fw-connectx4lx)等。该测试方法的测试环境要求服务器的磁盘大小至少为1gb、设备标识可以为最新mellanox的设备标识(deviceids)、操作系统为指定操作系统,如linux操作系统和安装权限等。

本申请的测试方法可以应用在数据通信网络(datacommunicationnetwork,dcn)中的rdma数据传输网络中,也可以应用于其他应用协议的tcp数据传输网络中。

下面以应用在数据通信网络(datacommunicationnetwork,dcn)中的rdma数据传输网络中为例进行说明。本申请的测试方法通过基于rdma创建的五元组数据结构,利用矩阵乘法(parallelmatrixmultiplication)算法实现了并发测试,得到测试报告,通过获取rdma的数据结构中源端口和目的端口的端口匹配数量,解决了当前无法仿真多用户的多种业务请求测试的限制,以及无法对多种业务请求并发性测试的问题,测试报告用于记录服务器处理并发性的多种业务请求的性能指标,性能指标可以包括处理多种业务请求的网络延迟、带宽、用户数量等。

以下结合说明书附图对本申请的优选实施例进行说明,应当理解,此处所描述的优选实施例仅用于说明和解释本发明,并不用于限定本发明,并且在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。

图1为本发明实施例提供的一种多种业务请求并发性测试方法的流程示意图。如图1所示,该方法可以包括:

步骤110、基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,第三矩阵包括第一数量的第四矩阵。

第一数量为预设的数量。

在执行该步骤之前,接收mpi测试的业务请求,根据业务请求中的端口和ip地址等信息,创建五元组的数据结构,五元组包括源端口、目的端口、源ip地址、目的ip地址、协议五种信息。

预设的第一矩阵与第二矩阵的行数和列数均大于预设阈值,且第一矩阵的列数和第二矩阵的行数相同,或第一矩阵的行数与第二矩阵的列数相同。例如,a矩阵为m*n的矩阵,m和n均大于预设阈值3000。b矩阵为n*k的矩阵,k和n均大于预设阈值3000。m、n和k均为大于零的正整数。

需要说明的是,第一矩阵与第二矩阵中的元素为随机数。

之后,启动第一数量的线程,每个线程用于处理一种业务请求,第一数量的线程用于将预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第一数量的第四矩阵。分别对第一矩阵与第二矩阵采用均分矩阵算法,得到均分后的第一矩阵和均分后的第二矩阵;每个第四矩阵是由一个线程处理得到的。均分后的第一矩阵和均分后的第二矩阵均包括第一数量的分矩阵。该均分矩阵算法用于将矩阵的行和列均等分,即矩阵的行和列都可以被整除,以得到分矩阵。

例如,m*n的a矩阵和n*k的b矩阵,采用均分矩阵算法,得到均分后的a矩阵和均分后的b矩阵;均分后的a矩阵包括a矩阵的第一数量的分矩阵a11-apk,均分后的b矩阵包括b矩阵的第一数量的分矩阵b11-bkq,可以表示为:

基于第一矩阵的第一数量的分矩阵和第二矩阵的第一数量的分矩阵,调用第一数量的线程分别采用预设乘法运算,将第一矩阵中每行分矩阵与第二矩阵中每列分矩阵相乘,得到第一数量的第四矩阵,即第一矩阵的每个分矩阵与第二矩阵的每个分矩阵的乘法运算由一个线程进行,每个第四矩阵对应一个线程,由于每个线程处理一种业务请求,故每个第四矩阵对应一种业务请求。

具体为:将第一矩阵中每行分矩阵与第二矩阵中每列分矩阵相乘,得到第一数量的第四矩阵。例如,将均分后的a矩阵中的第一行(a11a12...a1k)与均分后的b矩阵中的第一列(b11b21...bk1)相乘,得到第一个c矩阵:以此类推,得到第一数量的c矩阵。

可选地,在生成第一数量的c矩阵时,可以得到第一数量的c矩阵的生成时间。

步骤120、获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口。

采用矩阵求和算法对各个线程上的第四矩阵进行聚合,得到第三矩阵,第三矩阵包括第一数量的第四矩阵。在聚合过程中,基于各个线程间的通信,可以得到每个第四矩阵所在线程对应的源端口和目的端口,得到相应的五元组。

步骤130、基于每个第四矩阵与其对应的源端口,获取每个第四矩阵对应的一种业务请求和源端口对应的用户。

基于每个第四矩阵所在线程对应的源端口和相应目的端口的端口匹配信息,可以得到端口匹配数量,其中,当两个线程对应相同的源端口,且相同源端口对应不同目的端口时,两个线程的端口匹配信息不同;当两个线程对应不同的源端口,且不同的源端口对应相同的目的端口时,两个线程的端口匹配信息不同。源端口的数量对应发出业务请求的用户数量。通过端口匹配信息中源端口和目的端口的变化,得到不同的五元组,其中,不同的五元组包含的端口信息不同。

由此,根据每个第四矩阵与其对应的源端口,可以得到每个第四矩阵对应的一种业务请求和源端口对应的用户。

步骤140、根据第一数量的第四矩阵对应的业务请求和源端口对应的用户,生成多种业务请求并发性测试的测试报告。

基于每个第四矩阵对应的一种业务请求,得到第一数量的第四矩阵对应第一数量的务请求,基于每个第四矩阵所属线程对应的源端口对应用户,得到第一数量的第四矩阵对应的用户数量。之后,生成多种业务请求并发性测试的测试报告,测试报告包括并发性测试的第一数量的业务请求和第一数量的业务请求对应的用户数量。

可见,该方法通过测试是否能并行生成第一数量的第四矩阵,实现了第一数量业务请求的并行测试。

可选地,获取测试开始时间。

在生成多种业务请求并发性测试的测试报告之前,获取第三矩阵的生成时间,即第一数量的c矩阵的生成时间。

基于第一数量的第四矩阵、源端口对应的用户、第三矩阵的生成时间和测试开始时间,生成多种业务请求并发性测试的测试报告,此时测试报告包括并发性测试的第一数量的业务请求数量和第一数量的业务请求对应的用户数量,以及并发性测试的运行时间,由此实现了第一数量的业务请求的并发性测试。其中,该运行时间是基于第三矩阵的生成时间和测试开始时间,采用时间差值得到的。

进一步的,基于每个业务请求的运行时间和测试开始时间,采用时间差值运算,可以得到每个业务请求的网络延时。

本发明上述实施例的测试方法在基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,第三矩阵包括第一数量的第四矩阵,其中,每个第四矩阵是由一个线程处理得到的,第一矩阵与第二矩阵的行数和列数均大于预设阈值;获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口;基于第一数量的第四矩阵对应的业务请求和源端口对应的用户,生成多种业务请求并发性测试的测试报告,测试报告包括并发性测试的第一数量的业务请求和第一数量的业务请求对应的用户数量,该测试方法解决了当前无法仿真多用户的多种业务请求测试,以及无法对多种业务请求并发性测试的问题。

与上述方法对应的,本发明实施例还提供一种测试装置,如图2所示,该测试装置可以包括:运算单元210、获取单元220和生成单元230。

运算单元210,用于基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,其中,第三矩阵包括第一数量的第四矩阵,每个第四矩阵是由一个线程处理得到的,该线程用于处理一种业务请求,第一矩阵与第二矩阵的行数和列数均大于预设阈值;

获取单元220,用于获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口;基于每个第四矩阵与其对应的源端口,获取每个第四矩阵对应的业务请求和该源端口对应的用户;

生成单元230,用于根据第一数量的第四矩阵对应的业务请求和源端口对应的用户,生成多种业务请求并发性测试的测试报告,测试报告包括并发性测试的第一数量的并发性测试的业务请求数量和第一数量的业务请求对应的用户数量,以实现第一数量的业务请求的并发性测试。

可选地,所述装置还包括启动单元240;

启动单元240,用于在运算单元210基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵之前,启动第一数量的线程,第一数量的第四矩阵是第一数量的线程将预设的第一矩阵与第二矩阵采用矩阵乘法算法得到的。

可选地,运算单元210,具体用于分别对第一矩阵与第二矩阵,采用均分矩阵算法,得到第一矩阵的第一数量的分矩阵和第二矩阵的第一数量的分矩阵;调用第一数量的线程分别将第一矩阵中每行分矩阵与第二矩阵中每列分矩阵相乘,得到第一数量的第四矩阵。

可选地,获取单元220,具体用于采用矩阵求和算法对各个线程上的第四矩阵进行聚合,基于所述各个线程间的通信,获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口。

可选地,多种业务请求并发性测试的测试报告还包括测试开始时间;

获取单元220,还具体用于获取第三矩阵的生成时间;基于第三矩阵的生成时间和测试开始时间,采用时间差值运算,获取种业务请求并发性测试的运行时间。

本发明上述实施例的测试装置在基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,第三矩阵包括第一数量的第四矩阵,第一矩阵与第二矩阵的行数和列数均大于预设阈值;获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口;基于第一数量的第四矩阵、每个第四矩阵所属线程对应的源端口,生成多种业务请求并发性测试的测试报告,测试报告包括并发性测试的第一数量的业务请求和第一数量的业务请求对应的用户数量,该测试方法解决了当前无法仿真多用户的多种业务请求测试,以及无法对多种业务请求并发性测试的问题。

本发明实施例还提供了一种电子设备,如图3所示,包括处理器310、通信接口320、存储器330和通信总线340,其中,处理器310,通信接口320,存储器330通过通信总线340完成相互间的通信。

存储器330,用于存放计算机程序;

处理器310,用于执行存储器330上所存放的程序时,实现如下步骤:

基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,其中,第三矩阵包括第一数量的第四矩阵,每个第四矩阵是由一个线程处理得到的,所述线程用于处理一种业务请求,第一矩阵与第二矩阵的行数和列数均大于预设阈值;

获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口;

基于每个第四矩阵与其对应的源端口,获取所述每个第四矩阵对应的业务请求和所述源端口对应的用户;

根据第一数量的第四矩阵对应的业务请求和源端口对应的用户,生成多种业务请求并发性测试的测试报告,测试报告包括并发性测试的第一数量的并发性测试的业务请求数量和第一数量的业务请求对应的用户数量,以实现第一数量的业务请求的并发性测试。

可选地,基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵之前,启动第一数量的线程,第一数量的第四矩阵是第一数量的线程将预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第一数量的个第四矩阵的。

可选地,基于预设的第一矩阵与第二矩阵,采用矩阵乘法算法,得到第三矩阵,包括:

分别对第一矩阵与第二矩阵采用均分矩阵算法,得到第一矩阵的第一数量的分矩阵和第二矩阵的第一数量的分矩阵;

调用第一数量的线程分别将第一矩阵中每行分矩阵与第二矩阵中每列分矩阵相乘,得到第一数量的第四矩阵。

可选地,获取第一数量的第四矩阵中每个第四矩阵所属线程对应的端口信息,包括:

采用矩阵求和算法对各个线程上的第四矩阵进行聚合,基于各个线程间的通信,获取第一数量的第四矩阵中每个第四矩阵所属线程对应的源端口。

可选地,多种业务请求并发性测试的测试报告还包括测试开始时间;

生成多种业务请求并发性测试的测试信息之前,获取第三矩阵的生成时间;

基于该第三矩阵的生成时间和测试开始时间,采用时间差值运算,获取多种业务请求并发性测试的运行时间。

上述提到的通信总线可以是外设部件互连标准(peripheralcomponentinterconnect,pci)总线或扩展工业标准结构(extendedindustrystandardarchitecture,eisa)总线等。该通信总线可以分为地址总线、数据总线、控制总线等。为便于表示,图中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。

通信接口用于上述电子设备与其他设备之间的通信。

存储器可以包括随机存取存储器(randomaccessmemory,ram),也可以包括非易失性存储器(non-volatilememory,nvm),例如至少一个磁盘存储器。可选的,存储器还可以是至少一个位于远离前述处理器的存储装置。

上述的处理器可以是通用处理器,包括中央处理器(centralprocessingunit,cpu)、网络处理器(networkprocessor,np)等;还可以是数字信号处理器(digitalsignalprocessing,dsp)、专用集成电路(applicationspecificintegratedcircuit,asic)、现场可编程门阵列(field-programmablegatearray,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。

由于上述实施例中电子设备的各器件解决问题的实施方式以及有益效果可以参见图1所示的实施例中的各步骤来实现,因此,本发明实施例提供的电子设备的具体工作过程和有益效果,在此不复赘述。

在本发明提供的又一实施例中,还提供了一种计算机可读存储介质,该计算机可读存储介质中存储有指令,当其在计算机上运行时,使得计算机执行上述实施例中任一所述的测试方法。

在本发明提供的又一实施例中,还提供了一种包含指令的计算机程序产品,当其在计算机上运行时,使得计算机执行上述实施例中任一所述的测试方法。

本领域内的技术人员应明白,本申请实施例中的实施例可提供为方法、系统、或计算机程序产品。因此,本申请实施例中可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请实施例中可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产品的形式。

本申请实施例中是参照根据本申请实施例中实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。

这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。

这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。

尽管已描述了本申请实施例中的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例作出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请实施例中范围的所有变更和修改。

显然,本领域的技术人员可以对本申请实施例中实施例进行各种改动和变型而不脱离本申请实施例中实施例的精神和范围。这样,倘若本申请实施例中实施例的这些修改和变型属于本申请实施例中权利要求及其等同技术的范围之内,则本申请实施例中也意图包含这些改动和变型在内。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1