发明内容
为此,本发明提供一种负载机分配方案,以力图解决或者至少缓解上面存在的问题。
根据本发明的一个方面,提供一种负载机分配方法,适于在网络服务器中执行,网络服务器分别与用户端、调度服务器和云平台通信连接,云平台关联有一个或多个云资源,每个云资源均预先创建有一个或多个负载机镜像,用户端还与调度服务器通信连接,该方法包括如下步骤:首先,接收用户端发出的负载机分配请求,负载机分配请求包括用户需求;基于用户需求生成相应的配置信息;根据配置信息,通过云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机;若接收到创建成功消息,则向调度服务器注册发送创建成功消息的负载机,以指示调度服务器将该负载机分配给用户端;接收调度服务器反馈的注册状态消息;若注册状态消息指示该负载机注册成功,则向用户端发送相应的分配成功消息。
可选地,在根据本发明的负载机分配方法中,用户需求包括并发压力、特定区域和/或网络带宽。
可选地,在根据本发明的负载机分配方法中,配置信息包括负载机数量、创建区域、负载机信息、云资源名称和镜像标识中一个或多个。
可选地,在根据本发明的负载机分配方法中,根据配置信息,通过云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机的步骤包括:根据云资源名称获取与云平台关联的云资源;基于创建区域和镜像标识,确定与该云资源所对应的、待调用的一个或多个负载机镜像;按照负载机信息配置负载机镜像,以创建数量与负载机数量一致的负载机。
可选地,在根据本发明的负载机分配方法中,还包括:若接收到云平台反馈的创建失败消息,则通过云平台删除未创建成功的负载机,并释放相关网络资源。
可选地,在根据本发明的负载机分配方法中,还包括:若注册状态消息指示该负载机注册失败,则通过云平台删除该负载机,并释放相关网络资源。
可选地,在根据本发明的负载机分配方法中,还包括:响应用户端发出的任务完成消息,以通过云平台删除注册成功的负载机,并释放相关网络资源。
根据本发明的又一个方面,提供一种计算设备,包括一个或多个处理器、存储器以及一个或多个程序,其中一个或多个程序存储在存储器中并被配置为由一个或多个处理器执行,一个或多个程序包括用于执行根据本发明的负载机分配方法的指令。
根据本发明的又一个方面,提供一种存储一个或多个程序的计算机可读存储介质,一个或多个程序包括指令,指令当由计算设备执行时,使得计算设备执行根据本发明的负载机分配方法。
根据本发明的又一个方面,提供一种负载机分配方法,适于在负载机分配系统中执行,系统包括用户端、调度服务器、云平台和网络服务器,网络服务器分别与用户端、调度服务器和云平台通信连接,云平台关联有一个或多个云资源,每个云资源均预先创建有一个或多个负载机镜像,用户端还与调度服务器通信连接,该方法包括如下步骤:首先,用户端向网络服务器发送负载机分配请求,负载机分配请求包括用户需求;网络服务器接收用户端发出的负载机分配请求,基于用户需求生成相应的配置信息,并根据配置信息,通过云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机;若接收到创建成功消息,则向调度服务器注册发送创建成功消息的负载机;调度服务器根据注册情况生成注册状态消息,并向网络服务器发送注册状态消息,若注册成功,则向用户端分配该负载机;网络服务器接收调度服务器反馈的注册状态消息,若注册状态消息指示该负载机注册成功,则向用户端发送相应的分配成功消息。
可选地,在根据本发明的负载机分配方法中,用户需求包括并发压力、特定区域和/或网络带宽。
可选地,在根据本发明的负载机分配方法中,配置信息包括负载机数量、创建区域、负载机信息、云资源名称和镜像标识中一个或多个。
可选地,在根据本发明的负载机分配方法中,根据配置信息,通过云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机的步骤包括:根据云资源名称获取与云平台关联的云资源;基于创建区域和镜像标识,确定与该云资源所对应的、待调用的一个或多个负载机镜像;按照负载机信息配置负载机镜像,以创建数量与负载机数量一致的负载机。
可选地,在根据本发明的负载机分配方法中,还包括:云平台在负载机创建失败时,向网络服务器发送创建失败消息;网络服务器接收到创建失败消息,通过云平台删除未创建成功的负载机,并释放相关网络资源。
可选地,在根据本发明的负载机分配方法中,还包括:网络服务器在注册状态消息指示该负载机注册失败时,通过云平台删除该负载机,并释放相关网络资源。
可选地,在根据本发明的负载机分配方法中,还包括:用户端向网络服务器发送任务完成消息;网络服务器响应用户端发出的任务完成消息,以通过云平台删除注册成功的负载机,并释放相关网络资源。
根据本发明的又一个方面,还提供一种负载机分配系统,该系统包括用户端、调度服务器、云平台和网络服务器,网络服务器分别与用户端、调度服务器、云平台通信连接,用户端还与调度服务器通信连接。其中,用户端适于向网络服务器发送负载机分配请求,负载机分配请求包括用户需求;云平台适于关联一个或多个云资源,每个云资源均预先创建有一个或多个负载机镜像;网络服务器适于接收用户端发出的负载机分配请求,基于用户需求生成相应的配置信息,并根据配置信息,通过云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机,若接收到创建成功消息,则向调度服务器注册发送创建成功消息的负载机,若调度服务器反馈的注册状态消息指示该负载机注册成功,则向用户端发送相应的分配成功消息;调度服务器适于根据注册情况生成注册状态消息,并向网络服务器发送注册状态消息,若注册成功,则向用户端分配该负载机。
根据本发明的负载机分配的技术方案,首先接收用户端发出的负载机分配请求,通过云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机。若接收到创建成功消息,则向调度服务器注册发送创建成功消息的负载机,以指示调度服务器将该负载机分配给用户端,接收调度服务器反馈的注册状态消息,若注册状态消息指示该负载机注册成功,则向用户端发送相应的分配成功消息。在上述技术方案中,响应负载机分配请求,通过云平台调用合作的云资源来创建负载机,一方面实现多区域调用,另一方面在保证负载机正常启动运行后再告知用户,避免用户直接调用导致无法启用负载机的问题,节省压力测试节点的成本。其中,负载机分配请求包括用户需求,在创建负载机时,是先根据基于用户需求生成相应的配置信息,再根据该配置信息来对负载机镜像进行调用和设置,以实现满足用户需求的负载机的创建,有效解决了不同用户对负载机要求不均衡的问题。而且,云平台可关联多个云资源,在响应用户对负载机的分配请求时能提供丰富的云资源以便系统调配。进一步的,当负载机创建失败、注册失败以及用户的测试任务完成后,均会通过云平台对相应的负载机进行删除处理,并释放相关网络资源,减少不必要的资源浪费。
具体实施方式
下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。
图1示出了根据本发明一个实施例的负载机分配系统100的示意图。应当指出,图1中的负载机分配系统100仅是示例性的,在具体的实践情况中,负载机分配系统100可以有不同数量的用户端、调度服务器、云平台和网络服务器,本发明对负载机分配系统100中所包括的用户端、调度服务器、云平台和网络服务器的数量不做限制。如图1所示,网络服务器200分别与用户端500、调度服务器600和云平台700通信连接,用户端500还与调度服务器600通信连接。
根据本发明的一个实施例,用户端500中可内置有用于请求分配负载机的应用,在该应用的当前界面中显示有一个负载机分配需求页面,用户可在该页面中填入相应的用户需求,并点击该页面中的“开始分配”的按键图标以向网络服务器200发送负载机分配请求。其中,用户需求包括并发压力、特定区域和/或网络带宽。在该实施方式中,并发压力为600,表明需要600 个空闲线程来并发执行压力测试,特定区域为北京和上海,表明需要给用户分配位于北京和上海的负载机来进行压力测试,网络带宽为1G,表明执行压力测试时的带宽需求为1G。
此时,用户端500适于向网络服务器200发送该负载机分配请求,网络服务器200适于接收用户端500发出的负载机分配请求,基于用户需求生成相应的配置信息。根据该配置信息,网络服务器200通过云平台700调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机。
由于涉及到通过云平台700调用负载机镜像,此处先对其进行说明。云平台700适于关联一个或多个云资源,每个云资源均预先创建有一个或多个负载机镜像。简单来说,可以将云平台700理解为一个广义上的接口、应用或具备接口功能的服务器,这个接口或应用关联有多个云资源,这里的云资源可视为云公司,即提供云服务的运营商,比如阿里云、百度云、优刻得等。负载机镜像需要在云公司对应的各区域内预先创建,即在各个合作的云公司的控制台中,先创建一台云主机,对其进行镜像配置程序安装,再设置好开机启动与时间同步,关机后做成负载机镜像。不同的云资源通过云平台700 接入负载机分配系统100,从而网络服务器200在进行负载机创建时可随时调用负载机镜像来完成这一处理。
网络服务器200通过云平台700完成负载机的创建后,开始等待负载机是否创建成功的消息。根据本发明的一个实施例,网络服务器200创建了3 台负载机,分别即为T1、T2和T3。其中,负载机T1和T2创建成功,负载机T3创建失败,此时,负载机T1和T2会分别向网络服务器200发送对应的创建成功消息,云平台700向网络服务器200发送负载机T3对应的创建失败消息。将负载机T1对应的创建成功消息记为U1,负载机T2对应的创建成功消息记为U2,负载机T3对应的创建失败消息记为U3,则网络服务器200在接收到创建成功消息U1时,向调度服务器600注册发送创建成功消息U1的负载机T1,在接收到创建成功消息U2时,向调度服务器600注册发送创建成功消息U2的负载机T2,在接收到创建失败消息U3时,通过云平台700 删除未创建成功的负载机T3,并释放相关网络资源。
调度服务器600适于根据注册情况生成注册状态消息,并向网络服务器 200发送注册状态消息,若注册成功,则向用户端500分配该负载机。根据本发明的一个实施例,负载机T1注册成功,而负载机T2注册失败,对负载机 T1而言,调度服务器600根据注册成功的情况生成注册状态消息V1,注册状态消息V1指示负载机T1注册成功,向网络服务器200发送注册状态消息V1,并向用户端500分配负载机V1。对负载机T2而言,调度服务器600根据注册失败的情况生成注册状态消息V2,注册状态消息V2指示负载机T2注册失败,向网络服务器200发送注册状态消息V2。
网络服务器200接收调度服务器600发送的注册状态消息,若调度服务器600反馈的注册状态消息指示该负载机注册成功,则向用户端500发送相应的分配成功消息。根据本发明的一个实施例,网络服务器200接收到调度服务器600反馈的2条注册状态消息,分别是V1和V2,注册状态消息V1 指示负载机T1注册成功,则网络服务器200向用户端500发送与负载机T1 关联的分配成功消息W1,分配成功消息W1指示负载机T1已成功分配给当前用户。注册状态消息V2指示负载机T2注册失败,则网络服务器200通过云平台700删除负载机T2,并释放相关网络资源。
由于用户端500要发起的压力测试是需要3台负载机来执行的,此时分配给用户端500的只有1台,则用户端500可继续向网络服务器200发送负载机分配请求,以期再次分配。根据本发明的一个实施例,用户端500最终分配有负载机T1、T4和T5,当用户端500利用这3台负载机完成压力测试后,向网络服务器200发送任务完成消息,网络服务器200响应用户端500 发出的任务完成消息,以通过云平台700删除注册成功的负载机T1、T4和T5,并释放相关网络资源。关于以上网络服务器200具体执行负载机分配的过程,将在后续进行详细说明,此处暂且不表。
图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以及程序数据226。在一些实施方式中,程序222可以布置为在操作系统上由一个或多个处理器204利用程序数据224执行指令。
计算设备200还可以包括有助于从各种接口设备(例如,输出设备242、外设接口244和通信设备246)到基本配置102经由总线/接口控制器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实现为网络服务器,并被配置为执行根据本发明的负载机分配方法。其中,计算设备200的一个或多个程序222包括用于执行根据本发明的负载机分配方法的指令。
图3示出了根据本发明一个实施例的负载机分配方法300的流程图。如图3所示,方法300始于步骤S310,在步骤S310中,接收用户端500发出的负载机分配请求,负载机分配请求包括用户需求。其中,用户需求包括并发压力、特定区域和/或网络带宽。根据本发明的一个实施例,并发压力为600,表明需要600个空闲线程来并发执行压力测试,特定区域为北京和上海,表明需要给用户分配位于北京和上海的负载机来进行压力测试,网络带宽为1G,表明执行压力测试时的带宽需求为1G。
随后,进入步骤S320,基于用户需求生成相应的配置信息。根据本发明的一个实施例,配置信息包括负载机数量、创建区域、负载机信息、云资源名称和镜像标识中一个或多个。其中,负载机信息包括CPU信息、内存信息、内核版本、网卡信息、系统类型、固态硬盘信息和机械硬盘信息中的至少一个。在该实施方式中,配置信息包括负载机数量、创建区域、负载机信息、云资源名称和镜像标识,负载机信息包括CPU信息和内存信息。具体的,由于用户需求中的并发压力为600,特点区域为北京和上海,网络带宽为1G,据此生成的配置信息中,负载机数量为600/200=3台,200为每台负载机中可用于执行压力测试的空闲线程的数量,创建区域为北京和上海,负载机信息中的CPU信息指示每台负载机均具有4核CPU,且CPU主频为2.3GHz,内存信息指示每台负载机均具有8G内存,云资源名称为百度云,镜像标识为ID1 和ID2,其中ID1与北京区域的负载机镜像相关联,ID2与上海区域的镜像相关联。
在步骤S330中,根据配置信息,通过云平台700调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机。根据本发明的一个实施例,可通过如下方式根据配置信息创建负载机。首先,根据云资源名称获取与云平台700关联的云资源,再基于创建区域和镜像标识,确定与该云资源所对应的、待调用的一个或多个负载机镜像,最后按照负载机信息配置负载机镜像,以创建数量与负载机数量一致的负载机。在该实施方式中,云资源名称为百度云,则先获取与云平台700关联的百度云所具有的云资源。接下来,根据创建区域北京及其关联的镜像标识ID1,确定与该云资源所对应的、待调用的负载机镜像为M1,根据创建区域上海及其关联的镜像标识ID2,确定与该云资源所对应的、待调用的负载机镜像为M2。此后,按照步骤S320中所生成的负载机信息配置负载机镜像M1和M2,以创建3台负载机,其中根据负载机镜像M1创建出负载机T1和T2,根据负载机镜像M2创建出负载机 T3,负载机T1、T2和T3均具备4核CPU,且CPU主频为2.3GHz,内存为 8G。
当网络服务器200通过云平台700完成负载机的创建后,开始等待负载机是否创建成功的消息。若接收到创建成功消息,则执行步骤S340,向调度服务器600注册发送创建成功消息的负载机,以指示调度服务器600将该负载机分配给用户端500。根据本发明的一个实施例,负载机T1和T2创建成功,而负载机T3创建失败,则负载机T1和T2会分别向网络服务器200发送对应的创建成功消息,将负载机T1对应的创建成功消息记为U1,负载机T2 对应的创建成功消息记为U2。网络服务器200在接收到创建成功消息U1时,向调度服务器600注册发送创建成功消息U1的负载机T1,以指示调度服务器600将负载机T1分配给用户端500,而在接收到创建成功消息U2时,向调度服务器600注册发送创建成功消息U2的负载机T2,以指示调度服务器 600将负载T2分配给用户端500。对于创建失败的负载机T3,根据本发明的又一个实施例,网络服务器200在接收到云平台700发出的负载机T3对应的创建失败消息U3后,通过云平台700删除未创建成功的负载机T3,并释放相关网络资源。
在步骤S350中,接收调度服务器600反馈的注册状态消息。根据本发明的一个实施例,接收到调度服务器600反馈的注册状态消息V1和V2,其中注册状态消息V1指示负载机T1注册成功,表明调度服务器600成功向用户端500分配负载机V1,而注册状态消息V2指示负载机T2注册失败,表明调度服务器600并未成功向用户端500分配负载机V2。对于负载机T2,由于注册状态消息V2指示其注册失败,则根据本发明的又一个实施例,网络服务器 200通过云平台700删除负载机T2,并释放相关网络资源。
最后,执行步骤S360,若注册状态消息指示该负载机注册成功,则向用户端500发送相应的分配成功消息。根据本发明的一个实施例,注册状态消息V1指示负载机T1注册成功,则向用户端500发送与负载机T1关联的分配成功消息W1,分配成功消息W1指示负载机T1已成功分配给当前用户。
由于用户端500要发起的压力测试是需要3台负载机来执行的,此时分配给用户端500的只有1台,则用户端500可继续向网络服务器200发送负载机分配请求,以期再次分配。根据本发明的又一个实施例,用户端500最终分配有负载机T1、T4和T5,当用户端500利用这3台负载机完成压力测试后,向网络服务器200发送任务完成消息。网络服务器200响应用户端500 发出的任务完成消息,以通过云平台700删除注册成功的负载机T1、T4和 T5,并释放相关网络资源。
图4示出了根据本发明又一个实施例的负载机分配方法400的流程图。如图4所示,方法400始于步骤S411,在步骤S411中,用户端500向网络服务器200发送负载机分配请求,负载机分配请求包括用户需求。其中,用户需求包括并发压力、特定区域和/或网络带宽。根据本发明的一个实施例,并发压力为600,表明需要600个空闲线程来并发执行压力测试,特定区域为北京和上海,表明需要给用户分配位于北京和上海的负载机来进行压力测试,网络带宽为1G,表明执行压力测试时的带宽需求为1G。
网络服务器200在接收用户端500发出的负载机分配请求后,执行步骤 S421,基于用户需求生成相应的配置信息。根据本发明的一个实施例,配置信息包括负载机数量、创建区域、负载机信息、云资源名称和镜像标识中一个或多个。其中,负载机信息包括CPU信息、内存信息、内核版本、网卡信息、系统类型、固态硬盘信息和机械硬盘信息中的至少一个。在该实施方式中,配置信息包括负载机数量、创建区域、负载机信息、云资源名称和镜像标识,负载机信息包括CPU信息和内存信息。具体的,由于用户需求中的并发压力为600,特点区域为北京和上海,网络带宽为1G,据此生成的配置信息中,负载机数量为600/200=3台,200为每台负载机中可用于执行压力测试的空闲线程的数量,创建区域为北京和上海,负载机信息中的CPU信息指示每台负载机均具有4核CPU,且CPU主频为2.3GHz,内存信息指示每台负载机均具有8G内存,云资源名称为百度云,镜像标识为ID1和ID2,其中ID1 与北京区域的负载机镜像相关联,ID2与上海区域的镜像相关联。
接下来,在步骤S422中,网络服务器200根据配置信息,通过云平台700 调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机。根据本发明的一个实施例,可通过如下方式根据配置信息创建负载机。首先,根据云资源名称获取与云平台700关联的云资源,再基于创建区域和镜像标识,确定与该云资源所对应的、待调用的一个或多个负载机镜像,最后按照负载机信息配置负载机镜像,以创建数量与负载机数量一致的负载机。在该实施方式中,云资源名称为百度云,则先获取与云平台700关联的百度云所具有的云资源。接下来,根据创建区域北京及其关联的镜像标识ID1,确定与该云资源所对应的、待调用的负载机镜像为M1,根据创建区域上海及其关联的镜像标识ID2,确定与该云资源所对应的、待调用的负载机镜像为M2。此后,按照步骤S320中所生成的负载机信息配置负载机镜像M1和M2,以创建3 台负载机,其中根据负载机镜像M1创建出负载机T1和T2,根据负载机镜像M2创建出负载机T3,负载机T1、T2和T3均具备4核CPU,且CPU主频为2.3GHz,内存为8G。
网络服务器200通过云平台700完成负载机的创建后,开始等待负载机是否创建成功的消息。根据本发明的一个实施例,网络服务器200创建了3 台负载机,分别即为T1、T2和T3。其中,负载机T1和T2创建成功,负载机T3创建失败,此时,负载机T1和T2会分别向网络服务器200发送对应的创建成功消息,将负载机T1对应的创建成功消息记为U1,负载机T2对应的创建成功消息记为U2。对网络服务器200而言,若接收到创建成功消息,则执行步骤S423,向调度服务器600注册发送创建成功消息的负载机。在该实施方式中,网络服务器200在接收到创建成功消息U1时,向调度服务器600 注册发送创建成功消息U1的负载机T1,在接收到创建成功消息U2时,向调度服务器600注册发送创建成功消息U2的负载机T2。对于创建失败的负载机T3,根据本发明的又一个实施例,云平台700在负载机T3创建失败时,向网络服务器200发送创建失败消息U3,网络服务器200接收到创建失败消息U3,通过云平台700删除未创建成功的负载机T3,并释放相关网络资源。
在步骤S431中,调度服务器600根据注册情况生成注册状态消息。根据本发明的一个实施例,负载机T1注册成功,而负载机T2注册失败,对负载机T1而言,调度服务器600根据注册成功的情况生成注册状态消息V1,注册状态消息V1指示负载机T1注册成功,对负载机T2而言,调度服务器600 根据注册失败的情况生成注册状态消息V2,注册状态消息V2指示负载机T2 注册失败。
随后,调度服务器600执行步骤S432,向网络服务器200发送注册状态消息,若存在注册成功的负载机,则同时可执行步骤S433,向用户端500分配该负载机。根据本发明的一个实施例,调度服务器600向网络服务器200 发送注册状态消息V1和V2,由于注册状态消息V1指示负载机T1注册成功,则同时向用户端500分配负载机V1。
网络服务器200接收调度服务器600反馈的注册状态消息后,进入步骤 S424,若该注册状态消息指示该负载机注册成功,则向用户端500发送相应的分配成功消息。根据本发明的一个实施例,网络服务器200接收到调度服务器600反馈的2条注册状态消息,分别是V1和V2,注册状态消息V1指示负载机T1注册成功,则网络服务器200向用户端500发送与负载机T1关联的分配成功消息W1,分配成功消息W1指示负载机T1已成功分配给当前用户。对于负载机T2,由于注册状态消息V2指示其注册失败,则根据本发明的又一个实施例,网络服务器200在注册状态消息V2指示负载机T2注册失败时,通过云平台700删除负载机T2,并释放相关网络资源。
由于用户端500要发起的压力测试是需要3台负载机来执行的,此时分配给用户端500的只有1台,则用户端500可继续向网络服务器200发送负载机分配请求,以期再次分配。根据本发明的又一个实施例,用户端500最终分配有负载机T1、T4和T5,当用户端500利用这3台负载机完成压力测试后,向网络服务器200发送任务完成消息,网络服务器200响应用户端500 发出的任务完成消息,以通过云平台700删除注册成功的负载机T1、T4和 T5,并释放相关网络资源。
现有的基于云资源分配负载机的方法,大多数都是通过提供云资源的公司的控制台或简单的接口调用来完成的,导致用户调用负载机具备较大的难度,一旦某个环节出现问题又难以自行排查,体验较差。而且用户对负载机的需求并不均衡,数量要求不一,上述方法难以实现不同的数量及应用需求下的分化处理。根据本发明实施例的负载机分配的技术方案,首先接收用户端发出的负载机分配请求,通过云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机。若接收到创建成功消息,则向调度服务器注册发送创建成功消息的负载机,以指示调度服务器将该负载机分配给用户端,接收调度服务器反馈的注册状态消息,若注册状态消息指示该负载机注册成功,则向用户端发送相应的分配成功消息。在上述技术方案中,响应负载机分配请求,通过云平台调用合作的云资源来创建负载机,一方面实现多区域调用,另一方面在保证负载机正常启动运行后再告知用户,避免用户直接调用导致无法启用负载机的问题,节省压力测试节点的成本。其中,负载机分配请求包括用户需求,在创建负载机时,是先根据基于用户需求生成相应的配置信息,再根据该配置信息来对负载机镜像进行调用和设置,以实现满足用户需求的负载机的创建,有效解决了不同用户对负载机要求不均衡的问题。而且,云平台可关联多个云资源,在响应用户对负载机的分配请求时能提供丰富的云资源以便系统调配。进一步的,当负载机创建失败、注册失败以及用户的测试任务完成后,均会通过云平台对相应的负载机进行删除处理,并释放相关网络资源,减少不必要的资源浪费。
A7.如A1-6中任一项所述的方法,还包括:
响应所述用户端发出的任务完成消息,以通过所述云平台删除注册成功的负载机,并释放相关网络资源。
B11.如B10所述的方法,所述用户需求包括并发压力、特定区域和/或网络带宽。
B12.如B10或11所述的方法,所述配置信息包括负载机数量、创建区域、负载机信息、云资源名称和镜像标识中一个或多个。
B13.如B12所述的方法,所述根据所述配置信息,通过所述云平台调用其关联的云资源所对应的负载机镜像,以创建一台或多台负载机的步骤包括:
根据所述云资源名称获取与所述云平台关联的云资源;
基于所述创建区域和镜像标识,确定与该云资源所对应的、待调用的一个或多个负载机镜像;
按照所述负载机信息配置负载机镜像,以创建数量与所述负载机数量一致的负载机。
B14.如B10-13中任一项所述的方法,还包括:
云平台在负载机创建失败时,向所述网络服务器发送创建失败消息;
网络服务器接收到所述创建失败消息,通过所述云平台删除未创建成功的负载机,并释放相关网络资源。
B15.如B10-14中任一项所述的方法,还包括:
网络服务器在所述注册状态消息指示该负载机注册失败时,通过所述云平台删除该负载机,并释放相关网络资源。
B16.如B10-15中任一项所述的方法,还包括:
用户端向所述网络服务器发送任务完成消息;
网络服务器响应所述用户端发出的任务完成消息,以通过所述云平台删除注册成功的负载机,并释放相关网络资源。
在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下被实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。
类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。
本领域那些技术人员应当理解在本文所公开的示例中的设备的模块或单元或组间可以布置在如该实施例中所描述的设备中,或者可替换地可以定位在与该示例中的设备不同的一个或多个设备中。前述示例中的模块可以组合为一个模块或者此外可以分成多个子模块。
本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组间组合成一个模块或单元或组间,以及此外可以把它们分成多个子模块或子单元或子组间。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。
此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。
此外,所述实施例中的一些在此被描述成可以由计算机系统的处理器或者由执行所述功能的其它装置实施的方法或方法元素的组合。因此,具有用于实施所述方法或方法元素的必要指令的处理器形成用于实施该方法或方法元素的装置。此外,装置实施例的在此所述的元素是如下装置的例子:该装置用于实施由为了实施该发明的目的的元素所执行的功能。
这里描述的各种技术可结合硬件或软件,或者它们的组合一起实现。从而,本发明的方法和设备,或者本发明的方法和设备的某些方面或部分可采取嵌入有形媒介,例如软盘、CD-ROM、硬盘驱动器或者其它任意机器可读的存储介质中的程序代码(即指令)的形式,其中当程序被载入诸如计算机之类的机器,并被所述机器执行时,所述机器变成实践本发明的设备。
在程序代码在可编程计算机上执行的情况下,计算设备一般包括处理器、处理器可读的存储介质(包括易失性和非易失性存储器和/或存储元件),至少一个输入装置,和至少一个输出装置。其中,存储器被配置用于存储程序代码;处理器被配置用于根据该存储器中存储的所述程序代码中的指令,执行本发明的负载机分配方法。
以示例而非限制的方式,计算机可读介质包括计算机存储介质和通信介质。计算机可读介质包括计算机存储介质和通信介质。计算机存储介质存储诸如计算机可读指令、数据结构、程序模块或其它数据等信息。通信介质一般以诸如载波或其它传输机制等已调制数据信号来体现计算机可读指令、数据结构、程序模块或其它数据,并且包括任何信息传递介质。以上的任一种的组合也包括在计算机可读介质的范围之内。
如在此所使用的那样,除非另行规定,使用序数词“第一”、“第二”、“第三”等等来描述普通对象仅仅表示涉及类似对象的不同实例,并且并不意图暗示这样被描述的对象必须具有时间上、空间上、排序方面或者以任意其它方式的给定顺序。
尽管根据有限数量的实施例描述了本发明,但是受益于上面的描述,本技术领域内的技术人员明白,在由此描述的本发明的范围内,可以设想其它实施例。此外,应当注意,本说明书中使用的语言主要是为了可读性和教导的目的而选择的,而不是为了解释或者限定本发明的主题而选择的。因此,在不偏离所附权利要求书的范围和精神的情况下,对于本技术领域的普通技术人员来说许多修改和变更都是显而易见的。对于本发明的范围,对本发明所做的公开是说明性的,而非限制性的,本发明的范围由所附权利要求书限定。