掌桥专利:专业的专利平台
掌桥专利
首页

多节点服务器系统的动态测试方法、系统、装置及介质

文献发布时间:2023-06-29 06:30:04


多节点服务器系统的动态测试方法、系统、装置及介质

技术领域

本发明涉及计算机技术领域,更具体的说是涉及一种多节点服务器系统的动态测试方法、系统、装置及介质。

背景技术

多节点服务器是将多个服务器集中部署在了2U或4U的空间内,由2U或4U的系统机箱或提供统一供电散热单元、或提供共享存储单元、或提供统一的数据交换单元的服务器系统。在多节点服务器在九品马哥,每个节点自身是一个拥有完整功能的独立服务器,又依赖于整系统提供的供电、散热、存储等单元模块。此类服务器具有密度高,可拓展性强,可集中管理,易于集中部署等优势。

当前,针对多节点服务器系统的常规测试方法,是在需要进行多节点服务器整系统测试时,各节点采用同一测试内容进行测试。比如,加压测试时所有节点同时加压,系统重启测试时所有节点同时重启。这种测试方法可以有效的对产品单一功能点的上限进行有效测试。

但是,由于当前测试的手段是全部节点同时进行同一项测试内容,过于单一,缺乏灵活性;而且,此种测试方法无法有效模拟实际应用场景,不能同时满足整系统中的各节点独立运作时存在多种不同操作的情形。

发明内容

针对以上问题,本发明的目的在于提供一种多节点服务器系统的动态测试方法、系统、装置及介质,能够在多节点服务器的不同节点上自动化的选取多种不同的测试内容,有效的模拟实际应用场景。

本发明为实现上述目的,通过以下技术方案实现:一种多节点服务器系统的动态测试方法,包括如下步骤:

S1:安装测试工具并进行配置;

S2:将每个预设的测试内容映射为一个数字,根据所有的映射数字生成数组,作为测试内容集;

S3:选取N个测试节点,使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容;

S4:根据确定的测试内容,分别在N个测试节点执行测试;

S5:测试完成后,根据步骤S3的方法确定新的测试内容;

S6:分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合;

S7:对两个测试内容组合进行比对;若一致,则转到步骤S5,若不一致,则执行步骤S8;

S8:根据新的测试内容执行测试。

进一步,所述将每个预设的测试内容映射为一个数字包括:

将操作系统重启映射为1,将DC开关机映射为2,将CPU压力测试映射为3,将内存压力测试映射为4,将硬盘压力测试映射为5,将BMC压力测试映射为6,将BMC刷新测试映射为7,将BIOS刷新测试映射为8,将网卡FW刷新测试映射为9。

进一步,所述使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容,包括:

使用随机数生成函数,生成9个(0,1)之间的随机数,并生成随机数数组,根据生成顺序将每个随机数与映射数字对应;

使用最大值查找函数在随机数数组中依次选取N个最大值;

根据选取的随机数使用编码查找函数找到对应的映射数字,根据测试内容集和映射数字确定本次N个测试节点的测试内容。

进一步,所述分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合,包括:

将新的测试内容的N个映射数字按照从到大到小的顺序进行排序,生成第一测试内容组合;

将已完成的测试内容的N个映射数字按照从到大到小的顺序进行排序,生成第二测试内容组合。

进一步,所述步骤S7具体为:

对第一测试内容和第二测试内容组合进行比对;若完全一致,则转到步骤S5,若不一致,则执行步骤S8。

进一步,所述随机数生成函数采用rand()函数,所述最大值查找函数采用large()函数。

进一步,所述编码查找函数采用lookup()函数。

相应的,本发明还公开了一种多节点服务器系统的动态测试系统,包括:准备单元,用于安装测试工具并进行配置;

测试内容集组建单元,用于将每个预设的测试内容映射为一个数字,根据所有的映射数字生成数组,作为测试内容集;

测试内容选取单元,用于选取N个测试节点,使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容;

执行单元,用于根据确定的测试内容,分别在N个测试节点执行测试;

测试内容组合生成单元,用于分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合;

比对单元,用于对两个测试内容组合进行比对。

相应的,本发明公开了一种多节点服务器系统的动态测试装置,包括:

存储器,用于存储多节点服务器系统的动态测试程序;

处理器,用于执行所述多节点服务器系统的动态测试程序时实现如上文任一项所述多节点服务器系统的动态测试方法的步骤。

相应的,本发明公开了一种可读存储介质,所述可读存储介质上存储有多节点服务器系统的动态测试程序,所述多节点服务器系统的动态测试程序被处理器执行时实现如上文任一项所述多节点服务器系统的动态测试方法的步骤。

对比现有技术,本发明有益效果在于:本发明公开了一种多节点服务器系统的动态测试方法、系统、装置及介质,能够在多节点服务器的不同节点上自动化的选取多种不同的测试内容,有效的模拟实际应用场景,可以最大化的发现服务器开发中可能存在的漏洞,优化测试效果,提高对服务器质量的控制能力。

本发明将测试内容作为变量,按照节点数量随机抽取作为各节点测试内容的操作方式,实现了多节点随机使用不同测试内容同时进行验证,实现了一种可以有效的模拟实际应用中的具体场景的测试方法。

由此可见,本发明与现有技术相比,具有突出的实质性特点和显著的进步,其实施的有益效果也是显而易见的。

附图说明

为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图。

图1是本发明具体实施方式的方法流程图。

图2是本发明具体实施方式的系统结构图。

图中,1、准备单元;2、测试内容集组建单元;3、测试内容选取单元;4、执行单元;5、测试内容组合生成单元;6、比对单元。

具体实施方式

本发明的核心是提供一种多节点服务器系统的动态测试方法,现有技术中,针对多节点服务器系统的常规测试方法,是在需要进行多节点服务器整系统测试时,各节点采用同一测试内容进行测试。但是,由于当前测试的手段是全部节点同时进行同一项测试内容,过于单一,缺乏灵活性;而且,此种测试方法无法有效模拟实际应用场景,不能同时满足整系统中的各节点独立运作时存在多种不同操作的情形。

而本发明提供的多节点服务器系统的动态测试方法,首先,安装测试工具并进行配置,并将每个预设的测试内容映射为一个数字,根据所有的映射数字生成数组,作为测试内容集。然后,选取N个测试节点,使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容。测试内容确定后,根据确定的测试内容,分别在N个测试节点执行测试。测试完成后,根据前述的方法确定新的测试内容。此时,分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合,并对两个测试内容组合进行比对;如果一致则重新选取测试内容,如不一致则进行本轮测试。由此可见,本发明能够在多节点服务器的不同节点上自动化的选取多种不同的测试内容,有效的模拟实际应用场景。

为了使本技术领域的人员更好地理解本发明方案,下面结合附图和具体实施方式对本发明作进一步的详细说明。显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。

实施例一:

如图1所示,本实施例提供了一种多节点服务器系统的动态测试方法,包括如下步骤:

S1:安装测试工具并进行配置。

S2:将每个预设的测试内容映射为一个数字,根据所有的映射数字生成数组,作为测试内容集。

作为示例的,将每个预设的测试内容映射为一个数字具体如下:

将操作系统重启映射为1,将DC开关机映射为2,将CPU压力测试映射为3,将内存压力测试映射为4,将硬盘压力测试映射为5,将BMC压力测试映射为6,将BMC刷新测试映射为7,将BIOS刷新测试映射为8,将网卡FW刷新测试映射为9。

S3:选取N个测试节点,使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容。

具体来说,选取N个测试节点,使用rand()函数,生成9个(0,1)之间的随机数,并生成随机数数组,根据生成顺序将9个随机数与9个映射数字一一对应。此时,使用large()函数在随机数数组中依次选取N个最大值;根据选取的随机数使用lookup()函数找到对应的映射数字。最后,根据测试内容集和映射数字确定本次N个测试节点的测试内容。

作为示例的,选取3个测试节点,使用rand()函数,生成9个(0,1)之间的随机数,并生成随机数数组,具体为,(0.5,0.3,0.2,0.9,0.68,0.83,0.1,0.75,0.26)。根据生成顺序将9个随机数与9个映射数字一一对应,即0.5对应的映射数字为1,0.3对应的映射数字为2,0.2对应的映射数字为3,0.9对应的映射数字为4,0.68对应的映射数字为5,0.83对应的映射数字为6,0.1对应的映射数字为7,0.75对应的映射数字为8,0.26对应的映射数字为9。此时,使用large()函数在随机数数组中依次选取3个最大值,依次为0.9、0.75和0.68。根据选取的随机数使用lookup()函数找到对应的映射数字,即4、8和5。最后,根据测试内容集和映射数字确定本次3个测试节点的测试内容分别为:第一测试节点执行内存压力测试,第二测试节点执行BIOS刷新测试,第三测试节点执行硬盘压力测试。

需要说明的是,本步骤按照大小进行排序的是rand()函数生成的随机数,而其对应的测试内容映射数字则并未排序。

S4:根据确定的测试内容,分别在N个测试节点执行测试。

S5:测试完成后,根据步骤S3的方法确定新的测试内容。

具体的,按照上一步选取的测试内容,分别在N个测试节点执行不同的测试内容。待N个节点测试都完成后,再次重复步骤S3,进行下一轮测试的测试内容选取。

每次在进行选取内容集选取这一步时,使用rand()函数生成的随机数都是不同的,因此每次选取的前N个测试内容非常大概率的都是不同的组合。为了避免小概率出现相同组合,导致测试出现单一的情况,在此导入下一步。

S6:分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合。具体的,将新的测试内容的N个映射数字按照从到大到小的顺序进行排序,生成第一测试内容组合;将已完成的测试内容的N个映射数字按照从到大到小的顺序进行排序,生成第二测试内容组合。

S7:对两个测试内容组合进行比对;若一致,则转到步骤S5,若不一致,则执行步骤S8。

具体的,对第一测试内容和第二测试内容组合进行比对;若完全一致,则转到步骤S5,若不一致,则执行步骤S8。

S8:根据新的测试内容执行测试。

本实施例提供了一种多节点服务器系统的动态测试方法,不拘泥于单一的测试形式,在多节点服务器的不同节点上自动化的选取多种不同的测试内容,有效的模拟实际应用场景,可以最大化的发现服务器开发中可能存在的漏洞,优化测试效果,提高对服务器质量的控制能力。

实施例二:

基于实施例一,如图2所示,本发明还公开了一种多节点服务器系统的动态测试系统,包括:准备单元1、测试内容集组建单元2、测试内容选取单元3、执行单元4、测试内容组合生成单元5和比对单元6。

准备单元1,用于安装测试工具并进行配置。

测试内容集组建单元2,用于将每个预设的测试内容映射为一个数字,根据所有的映射数字生成数组,作为测试内容集。

测试内容选取单元3,用于选取N个测试节点,使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容。

执行单元4,用于根据确定的测试内容,分别在N个测试节点执行测试。

测试内容组合生成单元5,用于分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合。

比对单元6,用于对两个测试内容组合进行比对。

本实施例提供了一种多节点服务器系统的动态测试系统,能够在多节点服务器的不同节点上自动化的选取多种不同的测试内容,有效的模拟实际应用场景,可以最大化的发现服务器开发中可能存在的漏洞,优化测试效果,提高对服务器质量的控制能力。

实施例三:

本实施例公开了一种多节点服务器系统的动态测试装置,包括处理器和存储器;其中,所述处理器执行所述存储器中保存的多节点服务器系统的动态测试程序时实现以下步骤:

1、安装测试工具并进行配置。

2、将每个预设的测试内容映射为一个数字,根据所有的映射数字生成数组,作为测试内容集。

3、选取N个测试节点,使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容。

4、根据确定的测试内容,分别在N个测试节点执行测试。

5、测试完成后,根据步骤3的方法确定新的测试内容。

6、分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合。

7、对两个测试内容组合进行比对;若一致,则转到步骤5,若不一致,则执行步骤8。

8、根据新的测试内容执行测试。

进一步的,本实施例中的多节点服务器系统的动态测试装置,还可以包括:

输入接口,用于获取外界导入的多节点服务器系统的动态测试程序,并将获取到的多节点服务器系统的动态测试程序保存至所述存储器中,还可以用于获取外界终端设备传输的各种指令和参数,并传输至处理器中,以便处理器利用上述各种指令和参数展开相应的处理。本实施例中,所述输入接口具体可以包括但不限于USB接口、串行接口、语音输入接口、指纹输入接口、硬盘读取接口等。

输出接口,用于将处理器产生的各种数据输出至与其相连的终端设备,以便于与输出接口相连的其他终端设备能够获取到处理器产生的各种数据。本实施例中,所述输出接口具体可以包括但不限于USB接口、串行接口等。

通讯单元,用于在多节点服务器系统的动态测试装置和外部服务器之间建立远程通讯连接,以便于多节点服务器系统的动态测试装置能够将镜像文件挂载到外部服务器中。本实施例中,通讯单元具体可以包括但不限于基于无线通讯技术或有线通讯技术的远程通讯单元。

键盘,用于获取用户通过实时敲击键帽而输入的各种参数数据或指令。

显示器,用于运行服务器供电线路短路定位过程的相关信息进行实时显示。

鼠标,可以用于协助用户输入数据并简化用户的操作。

实施例四:

本实施例还公开了一种可读存储介质,这里所说的可读存储介质包括随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动硬盘、CD-ROM或技术领域内所公知的任意其他形式的存储介质。可读存储介质中存储有多节点服务器系统的动态测试程序,所述多节点服务器系统的动态测试程序被处理器执行时实现以下步骤:

1、安装测试工具并进行配置。

2、将每个预设的测试内容映射为一个数字,根据所有的映射数字生成数组,作为测试内容集。

3、选取N个测试节点,使用预设函数生成多个随机数,并将随机数与映射数字对应,为每个测试节点选取随机数,根据随机数对应的映射数字确定N个测试节点的测试内容。

4、根据确定的测试内容,分别在N个测试节点执行测试。

5、测试完成后,根据步骤3的方法确定新的测试内容。

6、分别根据新的测试内容和已完成的测试内容生成相应的测试内容组合。

7、对两个测试内容组合进行比对;若一致,则转到步骤5,若不一致,则执行步骤8。

8、根据新的测试内容执行测试。

综上所述,本发明能够在多节点服务器的不同节点上自动化的选取多种不同的测试内容,有效的模拟实际应用场景。

本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似部分互相参见即可。对于实施例公开的方法而言,由于其与实施例公开的系统相对应,所以描述的比较简单,相关之处参见方法部分说明即可。

专业人员还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。

在本发明所提供的几个实施例中,应该理解到,所揭露的系统、系统和方法,可以通过其它的方式实现。例如,以上所描述的系统实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,系统或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。

所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。

另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个模块单独物理存在,也可以两个或两个以上模块集成在一个单元中。

同理,在本发明各个实施例中的各处理单元可以集成在一个功能模块中,也可以是各个处理单元物理存在,也可以两个或两个以上处理单元集成在一个功能模块中。

结合本文中所公开的实施例描述的方法或算法的步骤可以直接用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机存储器(RAM)、内存、只读存储器(ROM)、电可编程ROM、电可擦除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其它形式的存储介质中。

最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。

以上对本发明所提供的多节点服务器系统的动态测试方法、系统、装置及可读存储介质进行了详细介绍。本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想。应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以对本发明进行若干改进和修饰,这些改进和修饰也落入本发明权利要求的保护范围内。

相关技术
  • 点播分发系统压力测试方法及装置、计算机装置及计算机存储介质
  • 一种服务器电压传感器测试方法、装置、终端及存储介质
  • 网管服务器测试方法、装置与系统
  • 移动通信系统性能的测试方法、装置和媒体仿真服务器
  • 一种固态硬盘性能测试方法、系统、装置及可读存储介质
  • 高密度多节点服务器测试方法、系统、终端及存储介质
  • 一种多节点服务器电源测试方法、系统、终端及存储介质
技术分类

06120116019162