一种脚本执行方法、装置及计算设备与流程

文档序号:13685675阅读:158来源:国知局
一种脚本执行方法、装置及计算设备与流程

本发明涉及软件测试领域,特别涉及一种脚本执行方法、装置及计算设备。



背景技术:

目前,互联网市场上各种软件层出不穷,不同业务逻辑和商业用途致使一个软件在传输数据和消息时,会使用不同类型的网络协议,除了较为常见的http/https协议外,还有websocket协议、mqtt协议等。由此可知,在对此类软件进行压力测试时,考虑到客户端对不同类型协议的需求,会涉及到各种协议的混发,那么在出现上述多协议混发现象时,就需要分别对不同的协议进行对应的压力测试。

然而,现有的压力测试方案在执行测试脚本时,通常是使用http协议来进行请求发送,而忽略了其他网络协议。随着技术的发展与革新,以后将会有更多新的协议作为压力测试的工具来进行客户端请求的发送,为了适应多协议混发的测试场景,提高新增协议下的快速功能迭代,需要一种新的脚本执行方案来改进上述处理过程。



技术实现要素:

为此,本发明提供一种脚本执行的技术方案,以力图解决或者至少缓解上面存在的问题。

根据本发明的一个方面,提供一种脚本执行方法,适于在计算设备中执行,该计算设备分别与调度服务器和文件服务器通信连接,文件服务器中存储有多个脚本文件,每个脚本文件关联有唯一的脚本标识且包括多个脚本单元,每个脚本单元具有对应的属性信息,属性信息包括协议标识和端口标识,该方法包括如下步骤:首先,接收调度服务器下发的脚本执行指令,脚本执行指令包括待执行脚本的脚本标识;从文件服务器中获取与脚本标识对应的脚本文件;对脚本文件执行序列化处理;解析序列化后的脚本文件以获取脚本实例,脚本实例包括多个与脚本单元对应的脚本单元实例;对各脚本单元进行排序处理以获取该脚本单元的执行次序;对于每个脚本单元,按照各脚本单元的执行次序,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例。

可选地,在根据本发明的脚本执行方法中,解析序列化后的脚本文件以获取脚本实例的步骤包括:对序列化后的脚本文件所包括的各个脚本单元分别进行解析;根据各脚本单元的协议标识和端口标识,实例化该脚本单元以生成对应的脚本单元实例;组合所生成的各脚本单元实例以形成与脚本文件对应的脚本实例。

可选地,在根据本发明的脚本执行方法中,属性信息还包括索引标识和引用标识,对各脚本单元进行排序处理以获取该脚本单元的执行次序的步骤包括:按照索引标识从小到大的顺序对各脚本单元进行一次排序;按照引用标识从小到大的顺序对具有相同索引标识的各脚本单元进行二次排序,以获取该脚本单元的执行次序。

可选地,在根据本发明的脚本执行方法中,计算设备还与超时控制服务器通信连接,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例的步骤包括:根据该脚本单元的协议标识和端口标识,利用相应的协议生成对应的请求;将该请求发送至超时控制服务器,以指示超时控制服务器在预设的第一时间间隔后返回超时状态;将该请求发送至相应的脚本单元实例,通过该脚本单元实例发送该请求以获取响应该请求的数据,再向超时控制服务发送取消该请求的超时控制指令;若接收到超时状态,则在预设的第二时间间隔后,将该请求重新发送至超时控制服务器和相应的脚本单元实例。

可选地,在根据本发明的脚本执行方法中,协议包括http协议、https协议、websocket协议、socket协议、mqtt协议、tcp协议和udp协议中的一个或多个。

根据本发明的又一个方面,提供一种脚本执行装置,适于驻留在计算设备中,该计算设备分别与调度服务器和文件服务器通信连接,文件服务器中存储有多个脚本文件,每个脚本文件关联有唯一的脚本标识且包括多个脚本单元,每个脚本单元具有对应的属性信息,属性信息包括协议标识和端口标识,该装置包括接收模块、获取模块、序列化模块、解析模块、排序模块和执行模块。其中,接收模块适于接收调度服务器下发的脚本执行指令,脚本执行指令包括待执行脚本的脚本标识;获取模块适于从文件服务器中获取与脚本标识对应的脚本文件;序列化模块适于对脚本文件执行序列化处理;解析模块适于解析序列化后的脚本文件以获取脚本实例,脚本实例包括多个与脚本单元对应的脚本单元实例;排序模块适于对各脚本单元进行排序处理以获取该脚本单元的执行次序;执行模块适于对于每个脚本单元,按照各脚本单元的执行次序,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例。

根据本发明的又一个方面,提供一种计算设备,包括根据本发明的脚本执行装置。

根据本发明的又一个方面,提供一种计算设备,包括一个或多个处理器、存储器以及一个或多个程序,其中一个或多个程序存储在存储器中并被配置为由一个或多个处理器执行,一个或多个程序包括用于执行根据本发明的脚本执行方法的指令。

根据本发明的又一个方面,还提供一种存储一个或多个程序的计算机可读存储介质,一个或多个程序包括指令,指令当由计算设备执行时,使得计算设备执行根据本发明的脚本执行方法。

根据本发明的脚本执行的技术方案,对获取到的脚本文件先执行序列化处理,再进行解析以获取脚本实例,该脚本实例包括多个与脚本单元对应的脚本单元实例,对各脚本单元进行排序处理以获取该脚本单元的执行次序,对于每个脚本单元,按照各脚本单元的执行次序,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例。在上述方案中,对序列化后的脚本文件进行解析处理时,是对脚本文件所包括的各个脚本单元进行分别解析,再根据各脚本单元的协议标识和端口标识来实例化以生成对应的脚本单元实例,以便后续利用与该脚本单元的协议和端口标识相应的协议来执行相应的脚本单元实例,便于对涉及多协议混发的客户端进行压力测试,能够适应更多的测试场景,并且在出现新的协议时还可以进行动态扩展,快速实现功能迭代,大大提高了新增协议解决方案的提出速度,进一步地,在执行脚本单元实例时,还通过超时控制单元来对执行时间进行控制,避免长时间不响应请求带来脚本执行陷入无响应状态或一直保持执行状态,浪费系统资源。此外,各脚本单元的执行次序是通过该脚本单元的索引标识和引用标识进行两次排序而生成的,保证了各脚本单元之间的关联性与层级关系。

附图说明

为了实现上述以及相关目的,本文结合下面的描述和附图来描述某些说明性方面,这些方面指示了可以实践本文所公开的原理的各种方式,并且所有方面及其等效方面旨在落入所要求保护的主题的范围内。通过结合附图阅读下面的详细描述,本公开的上述以及其它目的、特征和优势将变得更加明显。遍及本公开,相同的附图标记通常指代相同的部件或元素。

图1示出了根据本发明的一个实施例的脚本执行系统100的示意图;

图2示出了根据本发明的一个实施例的计算设备200的结构框图;

图3示出了根据本发明的一个实施例的脚本执行方法300的流程图;

图4示出了根据本发明的又一个实施例的脚本执行系统400的示意图;以及

图5示出了根据本发明的一个实施例的脚本执行装置500的示意图。

具体实施方式

下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。

图1示出了根据本发明一个实施例的脚本执行系统100的示意图。应当指出,图1中的脚本执行系统100仅是示例性的,在具体的实践情况中,脚本执行系统100中可以有不同数量的计算设备、调度服务器和文件服务器,本发明对脚本执行系统100中所包括的计算设备、调度服务器和文件服务器的数量不做限制。如图1所示,脚本执行系统100中包括计算设备200、调度服务器600和文件服务器700。其中,计算设备200分别与调度服务器600和文件服务器700通信连接,计算设备200可以是pc机,但不限于此。文件服务器700中存储有多个脚本文件,每个脚本文件关联有唯一的脚本标识且包括多个脚本单元,每个脚本单元具有对应的属性信息,属性信息包括协议标识和端口标识。具体来说,调度服务器600会向计算设备200下发脚本执行指令,该脚本执行指令包括待执行脚本的脚本标识,而计算设备200接收到调度服务器600下发的脚本执行指令后,从文件服务器700中获取与脚本标识对应的脚本文件,对脚本文件执行序列化处理,解析序列化后的脚本文件以获取脚本实例,脚本实例包括多个与脚本单元对应的脚本单元实例,对各脚本单元进行排序处理以获取该脚本单元的执行次序,对于每个脚本单元,按照各脚本单元的执行次序,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例。

图2是根据本发明的一个实施例的计算设备200的结构框图。在基本的配置202中,计算设备200典型地包括系统存储器206和一个或者多个处理器204。存储器总线208可以用于在处理器204和系统存储器206之间的通信。

取决于期望的配置,处理器204可以是任何类型的处理,包括但不限于:微处理器(μp)、微控制器(μc)、数字信息处理器(dsp)或者它们的任何组合。处理器204可以包括诸如一级高速缓存210和二级高速缓存212之类的一个或者多个级别的高速缓存、处理器核心214和寄存器216。示例的处理器核心214可以包括运算逻辑单元(alu)、浮点数单元(fpu)、数字信号处理核心(dsp核心)或者它们的任何组合。示例的存储器控制器218可以与处理器204一起使用,或者在一些实现中,存储器控制器218可以是处理器204的一个内部部分。

取决于期望的配置,系统存储器206可以是任意类型的存储器,包括但不限于:易失性存储器(诸如ram)、非易失性存储器(诸如rom、闪存等)或者它们的任何组合。系统存储器206可以包括操作系统220、一个或者多个程序222以及程序数据224。在一些实施方式中,程序222可以布置为在操作系统上由一个或多个处理器204利用程序数据224执行指令。

计算设备200还可以包括有助于从各种接口设备(例如,输出设备242、外设接口244和通信设备246)到基本配置202经由总线/接口控制器230的通信的接口总线240。示例的输出设备242包括图形处理单元248和音频处理单元250。它们可以被配置为有助于经由一个或者多个a/v端口252与诸如显示器或者扬声器之类的各种外部设备进行通信。示例外设接口244可以包括串行接口控制器254和并行接口控制器256,它们可以被配置为有助于经由一个或者多个i/o端口258和诸如输入设备(例如,键盘、鼠标、笔、语音输入设备、触摸输入设备)或者其他外设(例如打印机、扫描仪等)之类的外部设备进行通信。示例的通信设备246可以包括网络控制器260,其可以被布置为便于经由一个或者多个通信端口264与一个或者多个其他计算设备262通过网络通信链路的通信。

网络通信链路可以是通信介质的一个示例。通信介质通常可以体现为在诸如载波或者其他传输机制之类的调制数据信号中的计算机可读指令、数据结构、程序模块,并且可以包括任何信息递送介质。“调制数据信号”可以这样的信号,它的数据集中的一个或者多个或者它的改变可以在信号中编码信息的方式进行。作为非限制性的示例,通信介质可以包括诸如有线网络或者专线网络之类的有线介质,以及诸如声音、射频(rf)、微波、红外(ir)或者其它无线介质在内的各种无线介质。这里使用的术语计算机可读介质可以包括存储介质和通信介质二者。

计算设备200可以实现为服务器,例如文件服务器、数据库服务器、应用程序服务器和web服务器等,也可以实现为小尺寸便携(或者移动)电子设备的一部分,这些电子设备可以是诸如蜂窝电话、个人数字助理(pda)、个人媒体播放器设备、无线网络浏览设备、个人头戴设备、应用专用设备、或者可以包括上面任何功能的混合设备。计算设备200还可以实现为包括桌面计算机和笔记本计算机配置的个人计算机。在一些实施例中,计算设备200被配置为执行根据本发明的脚本执行方法300。程序222包括根据本发明的脚本执行装置500。

图3示出了根据本发明一个实施例的脚本执行方法300的流程图。脚本执行方法300适于在计算设备(例如图2所示的计算设备200)中执行。如图3所示,方法300始于步骤s310。在步骤s310中,接收调度服务器600下发的脚本执行指令,该脚本执行指令包括待执行脚本的脚本标识。根据本发明的一个实施例,调度服务器600下发的脚本执行指令中所包括的待执行脚本的脚本标识为s1。

随后,执行步骤s320,从文件服务器700中获取与脚本标识对应的脚本文件。根据本发明的一个实施例,文件服务器700中存储有100个脚本文件,分别为a1、a2、a3、……、a99和a100,每个脚本文件关联有唯一的脚本标识,依次为s1、s2、s3、……、s99和s100,且每个脚本文件包括多个脚本单元,而脚本单元具有对应的属性信息,属性信息包括协议标识和端口标识。在该实施方式中,获取到与脚本标识s1对应的脚本文件为a1,脚本文件a1的示例如下:

<httptransactionconfigname="事务_1"id="200"pid="2"index="1"goon="false">

<clazz>httptransactionconfig</clazz>

<configs>

<httppageconfigname="页_1"id="201"pid="200"index="1"goon="false"mainrequestid="202">

<clazz>httppageconfig</clazz>

<configs/>

<exearea>2</exearea>

<domain>10.128.106.20</domain>

<port>8081</port>

<protocol>http</protocol>

<path>/</path>

<method>get</method>

<fileargconfigs/>

……

</httptransactionconfig>

<socketconnectconfigname="socketconnect_1"id="18"pid="46"index="0"goon="false">

<clazz>socketconnectconfig</clazz>

<configs/>

<exearea>2</exearea>

<protocol>tcp</protocol>

<domain>10.128.106.20</domain>

<port>8088</port>

……

</socketconnectconfig>

对脚本文件a1而言,共包括3个脚本单元,从脚本参数“name”和“id”可知,这3个脚本单元的名称依次为“事务_1”、“页_1”和“socketconnect_1”,单元标识依次为200、201和18,将这3个脚本单元分别记为b11、b12和b13。对脚本单元b11和b12而言,从相关的“<protocol>http</protocol>”和“<port>8081</port>”语句可知,脚本单元b11和b12的协议标识为http,端口标识为8081,表明脚本单元b11和b12对应的协议为http协议,而对脚本单元b13来说,从相关的“<protocol>tcp</protocol>”和“<port>8088</port>”语句可知,脚本单元b13的协议标识为tcp,端口标识为8088,表明脚本单元b13对应的协议为tcp协议。需要说明的是,脚本文件的结构是固定的,除了协议标识为http的情况,其他协议标识所对应的协议在进行扩展时,都是在脚本参数“httptransactionconfig”下的“configs”下增加脚本单元,通过采用标签化的脚本格式,方便拓展脚本内容新的类型。

接下来,执行步骤s330,对脚本文件执行序列化处理。根据本发明的一个实施例,对脚本文件a1进行序列化以生成一个哈希结构,以便后续执行脚本时查找相应的可执行实例。关于上述序列化处理的具体算法,本发明并不限制,这些实现对应查找及关联存储的算法对于了解本发明方案的技术人员来说是可以容易想到的,并且也在本发明的保护范围之内,此处不予以赘述。

在步骤s340中,解析序列化后的脚本文件以获取脚本实例,脚本实例包括多个与脚本单元对应的脚本单元实例。根据本发明的一个实施例,可以通过下列方式解析序列化后的脚本文件以获取脚本实例。首先,对序列化后的脚本文件所包括的各个脚本单元分别进行解析,再根据各脚本单元的协议标识和端口标识,实例化该脚本单元以生成对应的脚本单元实例,最后组合所生成的各脚本单元实例以形成与脚本文件对应的脚本实例。在该实施方式中,对序列化后的脚本文件a1所包括的脚本单元b11、b12和b13分别进行解析,根据脚本单元b11和b12的协议标识http和端口标识8081,按照对应的协议,即http协议实例化这2个脚本单元以生成对应的脚本单元实例,得到脚本单元b11和b12对应的脚本单元示例分别是c11和c12,并根据脚本单元b13的协议标识tcp和端口标识8088,按照对应的协议,即tcp协议实例化脚本单元b13以生成对应的脚本单元实例c13,最后组合所生成的脚本单元实例c11、c12和c13以形成于脚本文件a1对应的脚本实例,将该脚本实例记为d1。

在完成脚本文件的解析处理后,进入步骤s350,对各脚本单元进行排序处理以获取该脚本单元的执行次序。根据本发明的一个实施例,属性信息还包括索引标识和引用标识,可以按照以下方法对各脚本单元进行排序处理以获取该脚本单元的执行次序。首先,按照索引标识从小到大的顺序对各脚本单元进行一次排序,然后,按照引用标识从小到大的顺序对具有相同索引标识的各脚本单元进行二次排序,以获取该脚本单元的执行次序。在该实施方式中,脚本参数“index”和“pid”分别表示索引标识和引用标识,则从脚本文件a1的内容可知,脚本单元b11、b12和b13的索引标识分别为1、1和0,先按照索引标识从小到大的顺序对脚本单元b11、b12和b13进行一次排序,此时这3个脚本单元的执行次序以脚本单元b1为首位,而脚本单元b12和b13的执行次序相同,进而再按照引用标识对具有相同索引标识的脚本单元b11和b12进行二次排序,脚本单元b11和b12的引用标识分别为2和200,可知这2个脚本单元的执行次序依次为脚本单元b11和b12,最后可得脚本单元b11、b12和b13的执行次序依次为脚本单元b13、b11和b12。

在确定了脚本文件的各个脚本单元的执行次序后,执行步骤s360,对于每个脚本单元,按照各脚本单元的执行次序,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例。其中,协议包括http协议、https协议、websocket协议、socket协议、mqtt协议、tcp协议和udp协议中的一个或多个。图4示出了根据本发明的又一个实施例的脚本执行系统400的示意图。如图4所示,脚本执行系统400中包括计算设备200、调度服务器600、文件服务器700和超时控制服务器800。其中,计算设备200除与调度服务器600和文件服务器700通信连接外,还和超时控制服务器800通信连接,则对每一个待执行的脚本单元,可通过下列方法来执行相应的脚本单元实例。首先,根据该脚本单元的协议标识和端口标识,利用相应的协议生成对应的请求,随后将该请求发送至超时。控制服务器800,以指示超时控制服务器800在预设的第一时间间隔后返回超时状态,同时将该请求发送至相应的脚本单元实例,通过该脚本单元实例发送该请求以获取响应该请求的数据,再向超时控制服务发送取消该请求的超时控制指令,若接收到超时状态,则在预设的第二时间间隔后,将该请求重新发送至超时控制服务器800和相应的脚本单元实例。为方便描述,以执行脚本单元b11对应的脚本单元实例c11为例进行说明。在该实施方式中,脚本单元b11的协议标识和端口标识分别是http和8081,则可知该脚本单元对应的协议为http协议,从而先利用http协议生成与脚本单元b11对应的http请求,而且从上述脚本文件a1的“<method>get</method>”语句可知,该http请求的类型为get类型。接下来,将该http请求发送至超时控制服务器800,在超时控制服务器800中并不会进行任何数据处理,只是在第一时间间隔后返回超时状态来提示脚本执行超时,上述超时状态将会返回到预先设置好的回调函数中。在向超时控制服务器800发送该http请求的同时,还会将该http请求发送至相应的脚本单元实例c11,在这里,脚本单元示例c11应理解为用于发送http请求的客户端。进而通过该客户端发送该http请求以获取响应该http请求的数据。

实际上,计算设备200还与测试服务器(图4中未示出)通信连接,该测试服务器用于接收与协议对应的请求,比如上述http请求,根据该请求来进行响应以生成测试结果,并将测试结果作为响应请求的数据返回给计算设备200,更确切地说是返回给发送该请求的客户端,再由该客户端反馈给回调函数,以便回调函数向超时控制服务器800发送取消该请求的超时控制指令。因此,在脚本单元实例c11作为客户端接收到测试服务器响应其发出的http请求的数据后,基于回调函数向超时控制服务器800发送取消命令,取消该http请求对应的超时控制,减轻超时控制服务器800的压力,避免资源浪费。需要注意的是,若接收到超时状态,则在第二时间间隔后,将该请求重新发送至超时控制服务器800和相应的脚本单元实例,一方面利用超时控制服务器800重新监控超时状态,另一方面指示相应的脚本单元示例继续发起该请求来获取响应数据,从而重新执行脚本。当然,若超时状态接收次数过多,则不再重新发送该请求至超时控制服务器800和相应的脚本单元实例,而是记录脚本错误以便后期调试来排查问题,防止大量发送无用请求和执行错误脚本导致不必要的系统资源和时间成本消耗。

图5示出了根据本发明一个实施例的脚本执行装置500的示意图。如图4所示,脚本执行装置500包括接收模块510、获取模块520、序列化模块530、解析模块540、排序模块550和执行模块560。

接收模块510适于接收调度服务器600下发的脚本执行指令,脚本执行指令包括待执行脚本的脚本标识。接收模块510执行上述操作的具体细节可参见方法300中的步骤s310,此处不予以赘述。

获取模块520与接收模块510相连,适于从文件服务器700中获取与脚本标识对应的脚本文件,脚本文件关联有唯一的脚本标识且包括多个脚本单元,每个脚本单元具有对应的属性信息,属性信息包括协议标识和端口标识。获取模块520执行上述操作的具体细节可参见方法300中的步骤s320,此处不予以赘述。

序列化模块530与获取模块520相连,适于对脚本文件执行序列化处理。序列化模块530执行上述操作的具体细节可参见方法300中的步骤s330,此处不予以赘述。

解析模块540与序列化模块530序列,适于解析序列化后的脚本文件以获取脚本实例,脚本实例包括多个与脚本单元对应的脚本单元实例。解析模块540进一步适于对序列化后的脚本文件所包括的各个脚本单元分别进行解析;根据各脚本单元的协议标识和端口标识,实例化该脚本单元以生成对应的脚本单元实例;组合所生成的各脚本单元实例以形成与脚本文件对应的脚本实例。解析模块540执行上述操作的具体细节可参见方法300中的步骤s340,此处不予以赘述。

排序模块550与序列化模块530相连,适于对各脚本单元进行排序处理以获取该脚本单元的执行次序。属性信息还包括索引标识和引用标识,排序模块550进一步适于按照索引标识从小到大的顺序对各脚本单元进行一次排序;按照引用标识从小到大的顺序对具有相同索引标识的各脚本单元进行二次排序,以获取该脚本单元的执行次序。排序模块550执行上述操作的具体细节可参见方法300中的步骤s350,此处不予以赘述。

执行模块560分别与解析模块540和排序模块550相连,适于对于每个脚本单元,按照各脚本单元的执行次序,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例。其中,协议包括http协议、https协议、websocket协议、socket协议、mqtt协议、tcp协议和udp协议中的一个或者多个。计算设备200还与超时控制服务器800通信连接,执行模块560进一步适于根据该脚本单元的协议标识和端口标识,利用相应的协议生成对应的请求;将该请求发送至超时控制服务器800,以指示超时控制服务器800在预设的第一时间间隔后返回超时状态;将该请求发送至相应的脚本单元实例中,通过该脚本单元实例发送该请求以获取响应该请求的数据,之后向超时控制服务发送取消该请求的超时控制指令;当接收到超时状态时,在预设的第二时间间隔后,将该请求重新发送至超时控制服务器800和相应的脚本单元实例。执行模块560执行上述操作的具体细节可参见方法300中的步骤s360,此处不予以赘述。

现有的对涉及多种协议混合发送的软件进行压力测试的方案中,在执行脚本时,通常是使用http协议来进行请求发送,忽略了其他网络协议,而且脚本格式不便于拓展与新增协议相关的脚本单元。根据本发明实施例的脚本执行的技术方案,对获取到的脚本文件先执行序列化处理,再进行解析以获取脚本实例,该脚本实例包括多个与脚本单元对应的脚本单元实例,对各脚本单元进行排序处理以获取该脚本单元的执行次序,对于每个脚本单元,按照各脚本单元的执行次序,根据该脚本单元的协议标识和端口标识,利用相应的协议来执行相应的脚本单元实例。在上述方案中,对序列化后的脚本文件进行解析处理时,是对脚本文件所包括的各个脚本单元进行分别解析,再根据各脚本单元的协议标识和端口标识来实例化以生成对应的脚本单元实例,以便后续利用与该脚本单元的协议和端口标识相应的协议来执行相应的脚本单元实例,便于对涉及多协议混发的客户端进行压力测试,能够适应更多的测试场景,并且在出现新的协议时还可以进行动态扩展,快速实现功能迭代,大大提高了新增协议解决方案的提出速度,进一步地,在执行脚本单元实例时,还通过超时控制单元来对执行时间进行控制,避免长时间不响应请求带来脚本执行陷入无响应状态或一直保持执行状态,浪费系统资源。此外,各脚本单元的执行次序是通过该脚本单元的索引标识和引用标识进行两次排序而生成的,保证了各脚本单元之间的关联性与层级关系。

b8.如b6或7所述的装置,所述属性信息还包括索引标识和引用标识,所述排序模块进一步适于:

按照所述索引标识从小到大的顺序对各脚本单元进行一次排序;

按照所述引用标识从小到大的顺序对具有相同索引标识的各脚本单元进行二次排序,以获取该脚本单元的执行次序。

b9.如b6-8中任一项所述的装置,所述计算设备还与超时控制服务器通信连接,所述执行模块进一步适于:

根据该脚本单元的协议标识和端口标识,利用相应的协议生成对应的请求;

将该请求发送至所述超时控制服务器,以指示所述超时控制服务器在预设的第一时间间隔后返回超时状态;

将该请求发送至相应的脚本单元实例中,通过该脚本单元实例发送该请求以获取响应该请求的数据,之后向所述超时控制服务发送取消该请求的超时控制指令;

当接收到所述超时状态时,在预设的第二时间间隔后,将该请求重新发送至所述超时控制服务器和相应的脚本单元实例。

b10.如b6-9中任一项所述的装置,所述协议包括http协议、https协议、websocket协议、socket协议、mqtt协议、tcp协议和udp协议中的一个或者多个。

在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。

类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。

本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组间可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。

本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组间组合成一个模块或单元或组间,以及此外可以把它们分成多个子模块或子单元或子组间。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。

此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。

此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。

这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如软盘、cd-rom、硬盘驱动器或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。

在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的脚本执行方法。

以示例而非限制的方式,计算机可读介质包括计算机存储介质和通信介质。计算机可读介质包括计算机存储介质和通信介质。计算机存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在计算机可读介质的范围之内。

如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。

尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。

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