服务器调用方法及装置的制造方法

文档序号:10691168阅读:178来源:国知局
服务器调用方法及装置的制造方法
【专利摘要】本发明实施例提供一种服务器调用方法及装置。该方法包括:第一Docker服务器接收任务执行指令;第一Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器;第一Docker服务器将任务执行指令发送给目标Docker服务器,以使目标Docker服务器执行任务执行指令,并将执行结果返回给第一Docker服务器。本发明实施例用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,提高了用户访问和调度Docker服务器的效率。
【专利说明】
服务器调用方法及装置
技术领域
[0001 ]本发明实施例涉及通信技术领域,尤其涉及一种服务器调用方法及装置。
【背景技术】
[0002]Docker是一个开源的应用容器引擎,在物理主机上安装Docker后,可在Docker的基础上承载多个容器,多个容器之间相互隔离,多个容器共享物理主机的操作系统,各容器可放置并执行不同的应用程序。
[0003]将安装有Docker的物理主机称为Docker服务器,现有技术中,多个Docker服务器可能在同一个子网中,用户登录同一个子网内的一个Docker服务器,访问和调度该Docker服务器的资源,当该Docker服务器的资源不够用时,用户需要逐一登录到同一个子网内的其他Docker服务器进行资源访问和调度。
[0004]由于用户需要逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而降低了用户访问和调度Docker服务器的效率。

【发明内容】

[0005]本发明实施例提供一种服务器调用方法及装置,以提高用户访问和调度Docker服务器的效率。
[0006]本发明实施例的一个方面是提供一种服务器调用方法,包括:
[0007]第一Docker服务器接收任务执行指令;
[0008]所述第一Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器;
[0009]所述第一Docker服务器将所述任务执行指令发送给所述目标Docker服务器,以使所述目标Docker服务器执行所述任务执行指令,并将执行结果返回给所述第一 Docker服务器。
[0010]本发明实施例的另一个方面是提供一种服务器调用装置,包括:
[0011]接收模块,用于接收任务执行指令;
[0012]确定模块,用于根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器;
[0013]发送模块,用于将所述任务执行指令发送给所述目标Docker服务器,以使所述目标Docker服务器执行所述任务执行指令,并将执行结果返回给所述第一 Docker服务器。
[0014]本发明实施例提供的服务器调用方法及装置,通过用户登录同一个子网内的任意一个Docker服务器,并向该Docker服务器输入任务执行指令,由该Docker服务器从该子网内的多个Docker服务器中确定出目标Docker服务器,确定目标Docker服务器的依据是该子网内各Docker服务器的资源占用率的大小,该Docker服务器将任务执行指令发送给目标Docker服务器,由目标Docker服务器执行该任务执行指令,并将执行结果返回给该Docker服务器,即用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而提高了用户访问和调度Docker服务器的效率。
【附图说明】
[0015]图1为本发明实施例提供的服务器调用方法流程图;
[0016]图2为本发明实施例提供的服务器调用方法适用的网络结构图;
[0017]图3为本发明另一实施例提供的服务器调用方法流程图;
[0018]图4为本发明实施例提供的服务器调用装置的结构图;
[0019]图5为本发明另一实施例提供的服务器调用装置的结构图。
【具体实施方式】
[0020]图1为本发明实施例提供的服务器调用方法流程图;图2为本发明实施例提供的服务器调用方法适用的网络结构图。本发明实施例针对用户需要逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而降低了用户访问和调度Docker服务器的效率,提供了服务器调用方法,该方法具体步骤如下:
[0021]步骤S101、第一Docker服务器接收任务执行指令;
[0022]如图2所示,交换机10与多个Docker服务器连接,其中,Docker服务器21、Docker月艮务器22、Docker服务器23属于同一个子网,Docker服务器31、Docker服务器32属于同一个子网,具体地,Docker服务器21、Docker服务器22、Docker服务器23属于虚拟局域网(VirtualLocal Area Network,简称VLAN) 100,VLANl00属于用户A;Docker服务器31、Docker服务器32 属于 VLAN200,VLAN200 属于用户B。
[0023]本发明实施例中,用户登录同一个子网内的Docker服务器,Docker服务器启动一个镜像Docker,用户通过该镜像Docker访问和调度该子网内各Docker服务器的资源,具体地,用户从同一个子网内选择任意一个Docker服务器进行登录,例如,用户登录了VLAN100中的Docker服务器21称为第一Docker服务器,Docker服务器21启动一个镜像Docker,Docker服务器21提供有交互界面,用户通过交互界面输入任务执行指令,例如,运行应用程序APP的指令。
[0024]步骤S102、所述第一 Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器。
[0025]优选地,所述Docker服务器集中各Docker服务器在同一个子网中。所述第一Docker服务器存储有成员表,所述成员表包括所述Docker服务器集中各Docker服务器的标识信息、IP地址和资源占用率。
[0026]本发明实施例将同一个子网的各Docker服务器的集合称为Docker服务器集,例如,VLAN100内的Docker服务器21、Docker服务器22、Docker服务器23构成Docker服务器集I,VLAN200内的Docker服务器31、Docker服务器32构成Docker服务器集2。以Docker服务器集I为例,Docker服务器集I中的各Docker服务器即Docker服务器21、Docker服务器22、Docker服务器23均维护有一个成员表,该成员表包括Docker服务器21、Docker服务器22、Docker服务器23分别对应的标识信息、IP地址和资源占用率。
[0027]成员表的建立过程如下:Docker服务器21计算本地的资源占用率,并将Docker服务器21的标识信息、IP地址和资源占用率广播到VLAN100内中,Docker服务器22、Docker月艮务器23均可接收到Docker服务器21广播的信息。以Docker服务器22为例,当Docker服务器22接收到Docker服务器21广播的标识信息、IP地址和资源占用率后,查看本地维护的成员表是否包括Docker服务器21的标识信息、IP地址,即判断Docker服务器21是否为VLAN100内新增加的成员,若是,则Docker服务器22将该广播信息作为新的条目直接添加在本地的成员表中,若否,则将本地成员表中已经存储的Docker服务器21对应的条目的内容更新为该广播信息的内容,即将本地成员表中已经存储的Docker服务器21的标识信息、IP地址和资源占用率更新为Docker服务器21最新广播的标识信息、IP地址和资源占用率。Docker服务器23的操作同理于Docker服务器22的操作。另外,Docker服务器23和Docker服务器22同理执行Docker服务器21的操作。
[0028]具体地,以Docker服务器21为第一 Docker服务器,当Docker服务器21接收到用户输入的任务执行指令后,查看本地的成员表,通过该成员表查询VLAN100内Docker服务器
21、Docker服务器22、Docker服务器23分别对应的资源占用率,通过各Docker服务器资源占用率的大小,确定出目标Docker服务器。
[0029]步骤S103、所述第一Docker服务器将所述任务执行指令发送给所述目标Docker服务器,以使所述目标Docker服务器执行所述任务执行指令,并将执行结果返回给所述第一Docker服务器。
[0030]Docker服务器21确定出目标Docker服务器后,将该任务执行指令发送给所述目标Docker服务器,由所述目标Docker服务器执行该任务执行指令,所述目标Docker服务器将运行结果返回给Docker服务器21,Docker服务器21将该运行结果返回到交互界面以供用户查看。
[0031]本发明实施例通过用户登录同一个子网内的任意一个Docker服务器,并向该Docker服务器输入任务执行指令,由该Docker服务器从该子网内的多个Docker服务器中确定出目标Docker服务器,确定目标Docker服务器的依据是该子网内各Docker服务器的资源占用率的大小,该Docker服务器将任务执行指令发送给目标Docker服务器,由目标Docker服务器执行该任务执行指令,并将执行结果返回给该Docker服务器,即用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而提高了用户访问和调度Docker服务器的效率。
[0032]图3为本发明另一实施例提供的服务器调用方法流程图;在图1对应的实施例的基础上,本发明实施例提供的服务器调用方法的具体步骤如下:
[0033]步骤S301、第一Docker服务器接收任务执行指令。
[0034]在本发明实施例中任务执行指令包括两种指令,一种指令是非全局指令,一种指令是全局指令。
[0035]步骤S302、所述第一 Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器;
[0036]所述目标Docker服务器是所述Docker服务器集中资源占用率低于阈值的第二Docker服务器;或者所述目标Docker服务器是所述Docker服务器集中除所述第一 Docker服务器之外的Docker服务器。
[0037]当任务执行指令是非全局指令时,所述第一Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率的大小,确定出资源占用率低于阈值的Docker服务器,并从资源占用率低于阈值的Docker服务器中任意选择一个Docker服务器即第二 Docker服务器作为目标Docker服务器。例如,上述实施例中,Docker服务器21依据本地的成员表,判断Docker服务器21、Docker服务器22、Docker服务器23分别对应的资源占用率,并确定出资源占用率低于阈值的Docker服务器包括Docker服务器22、Docker服务器23 ,Docker服务器21从Docker服务器22、Docker服务器23中任意选取一个Docker服务器例如Docker服务器22作为目标Docker服务器。
[0038]当任务执行指令是全局指令时,第一Docker服务器将所述Docker服务器集中除所述第一Docker服务器之外的Docker服务器作为目标Docker服务器。例如,Docker服务器21将本地成员表中包括的Docker服务器22、Docker服务器23均作为目标Docker服务器。
[0039]步骤S303、所述第一 Docker服务器将所述任务执行指令发送给所述目标Docker服务器,以使所述目标Docker服务器执行所述任务执行指令,并将执行结果返回给所述第一Docker服务器;
[0040]根据步骤S302,若任务执行指令是非全局指令,Docker服务器21将Docker服务器22作为目标Docker服务器,则Docker服务器21将所述任务执行指令发送给Docker服务器22,由Docker服务器22执行所述任务执行指令,并将执行结果返回给Docker服务器21。
[0041]根据步骤S302,若任务执行指令是全局指令,Docker服务器21将Docker服务器22、Docker服务器23均作为目标Docker服务器,则同一个所述任务执行指令分别由Docker服务器22、Docker服务器23执行,例如,Docker服务器21将所述任务执行指令对应的任务分为多个子任务,并将不同的子任务分配给Docker服务器22、Docker服务器23执行,Docker服务器
22、Docker服务器23将执行子任务的结果返回给Docker服务器21 ,Docker服务器21将多个子任务的结果合成为任务结果,并将任务结果显示在与用户交互的界面上供用户查看。
[0042]步骤S304、所述第一 Docker服务器计算所述第一 Docker服务器的资源占用率;
[0043]在本发明实施例中,同一个子网内的各Docker服务器周期性的计算本地的资源占用率,各Docker服务器计算到本地新的资源占用率后,向该子网内广播信息,该广播信息包括Docker服务器的标识信息、IP地址和资源占用率。本发明实施例以VLAN100中的Docker服务器21为例,Docker服务器21计算本地的资源占用率。
[0044]步骤S305、所述第一 Docker服务器将所述第一 Docker服务器的标识信息、IP地址和资源占用率广播到所述Docker服务器集中,以使所述Docker服务器集中除所述第一Docker服务器之外的Docker服务器将所述第一 Docker服务器的标识信息、IP地址和资源占用率更新到所述成员表。
[0045]Docker服务器21将Docker服务器21的标识信息、IP地址和资源占用率广播到VLAN100内中。Docker服务器22、Docker服务器23均可接收到Docker服务器21广播的信息。以Docker服务器22为例,当Docker服务器22接收到Docker服务器21广播的标识信息、IP地址和资源占用率后,查看本地维护的成员表是否包括Docker服务器21的标识信息、IP地址,即判断Docker服务器21是否为VLAN100内新增加的成员,若是,则Docker服务器22将该广播信息作为新的条目直接添加在本地的成员表中,若否,则将本地成员表中已经存储的Docker服务器21对应的条目的内容更新为该广播信息的内容,即将本地成员表中已经存储的Docker服务器21的标识信息、IP地址和资源占用率更新为Docker服务器21最新广播的标识信息、IP地址和资源占用率。Docker服务器23的操作同理于Docker服务器22的操作。
[0046]需要注意的是,步骤S304与步骤S301、步骤S302、步骤S303没有执行顺序,即步骤S304可以在步骤S301、步骤S302、步骤S303中的任意一个步骤之前或之后执行;同理,步骤S305与步骤S301、步骤S302、步骤S303没有执行顺序。
[0047]本发明实施例通过任务执行指令包括两种指令,一种指令是非全局指令,一种指令是全局指令,当任务执行指令是非全局指令时,第一 Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率的大小,确定出资源占用率低于阈值的Docker服务器,并从资源占用率低于阈值的Docker服务器中任意选择一个Docker服务器即第二Docker服务器作为目标Docker服务器;当任务执行指令是全局指令时,第一Docker服务器将Docker服务器集中除第一Docker服务器之外的Docker服务器作为目标Docker服务器,SP用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而提高了用户访问和调度Docker服务器的效率。
[0048]图4为本发明实施例提供的服务器调用装置的结构图。本发明实施例提供的服务器调用装置可以执行服务器调用方法实施例提供的处理流程,如图4所示,服务器调用装置40包括接收模块41、确定模块42和发送模块43,其中,接收模块41用于接收任务执行指令;确定模块42用于根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器;发送模块43用于将所述任务执行指令发送给所述目标Docker服务器,以使所述目标Docker服务器执行所述任务执行指令,并将执行结果返回给所述第一 Docker服务器。
[0049]本发明实施例提供的服务器调用装置可以具体用于执行上述图1所提供的方法实施例,具体功能此处不再赘述。
[0050]本发明实施例通过用户登录同一个子网内的任意一个Docker服务器,并向该Docker服务器输入任务执行指令,由该Docker服务器从该子网内的多个Docker服务器中确定出目标Docker服务器,确定目标Docker服务器的依据是该子网内各Docker服务器的资源占用率的大小,该Docker服务器将任务执行指令发送给目标Docker服务器,由目标Docker服务器执行该任务执行指令,并将执行结果返回给该Docker服务器,即用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而提高了用户访问和调度Docker服务器的效率。
[0051]图5为本发明另一实施例提供的服务器调用装置的结构图。在上述实施例的基础上,所述Docker服务器集中各Docker服务器在同一个子网中。
[0052]所述目标Docker服务器是所述Docker服务器集中资源占用率低于阈值的第二Docker服务器;或者所述目标Docker服务器是所述Docker服务器集中除所述第一 Docker服务器之外的Docker服务器。
[0053]所述第一Docker服务器存储有成员表,所述成员表包括所述Docker服务器集中各Docker服务器的标识信息、IP地址和资源占用率。
[0054]服务器调用装置40还包括计算模块44,计算模块44用于计算所述第一Docker服务器的资源占用率;发送模块43还用于将所述第一Docker服务器的标识信息、IP地址和资源占用率广播到所述Docker服务器集中,以使所述Docker服务器集中除所述第一Docker服务器之外的Docker服务器将所述第一 Docker服务器的标识信息、IP地址和资源占用率更新到所述成员表。
[0055]本发明实施例提供的服务器调用装置可以具体用于执行上述图3所提供的方法实施例,具体功能此处不再赘述。
[0056]本发明实施例通过任务执行指令包括两种指令,一种指令是非全局指令,一种指令是全局指令,当任务执行指令是非全局指令时,第一 Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率的大小,确定出资源占用率低于阈值的Docker服务器,并从资源占用率低于阈值的Docker服务器中任意选择一个Docker服务器即第二Docker服务器作为目标Docker服务器;当任务执行指令是全局指令时,第一Docker服务器将Docker服务器集中除第一Docker服务器之外的Docker服务器作为目标Docker服务器,SP用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而提高了用户访问和调度Docker服务器的效率。
[0057]综上所述,本发明实施例通过用户登录同一个子网内的任意一个Docker服务器,并向该Docker服务器输入任务执行指令,由该Docker服务器从该子网内的多个Docker服务器中确定出目标Docker服务器,确定目标Docker服务器的依据是该子网内各Docker服务器的资源占用率的大小,该Docker服务器将任务执行指令发送给目标Docker服务器,由目标Docker服务器执行该任务执行指令,并将执行结果返回给该Docker服务器,即用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而提高了用户访问和调度Docker服务器的效率;通过任务执行指令包括两种指令,一种指令是非全局指令,一种指令是全局指令,当任务执行指令是非全局指令时,第一 Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率的大小,确定出资源占用率低于阈值的Docker服务器,并从资源占用率低于阈值的Docker服务器中任意选择一个Docker服务器即第二Docker服务器作为目标Docker服务器;当任务执行指令是全局指令时,第一Docker服务器将Docker服务器集中除第一Docker服务器之外的Docker服务器作为目标Docker服务器,即用户只需登录同一个子网内的任意一个Docker服务器,便可访问和调用该子网内的各Docker服务器的资源,避免用户逐一登录到同一个子网内的各Docker服务器进行资源访问和调度,因而提高了用户访问和调度Docker服务器的效率。
[0058]在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
[0059]所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
[0060]另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
[0061]上述以软件功能单元的形式实现的集成的单元,可以存储在一个计算机可读取存储介质中。上述软件功能单元存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)或处理器(processor)执行本发明各个实施例所述方法的部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-Only Memory,R0M)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
[0062]本领域技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。上述描述的装置的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
[0063]最后应说明的是:以上各实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述各实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围。
【主权项】
1.一种服务器调用方法,其特征在于,包括: 第一 Docker服务器接收任务执行指令; 所述第一 Docker服务器根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器; 所述第一 Docker服务器将所述任务执行指令发送给所述目标Docker服务器,以使所述目标Docker服务器执行所述任务执行指令,并将执行结果返回给所述第一 Docker服务器。2.根据权利要求1所述的方法,其特征在于,所述Docker服务器集中各Docker服务器在同一个子网中。3.根据权利要求2所述的方法,其特征在于,所述目标Docker服务器是所述Docker服务器集中资源占用率低于阈值的第二 Docker服务器;或者 所述目标Docker服务器是所述Docker服务器集中除所述第一 Docker服务器之外的Docker服务器。4.根据权利要求1-3任一项所述的方法,其特征在于,所述第一Docker服务器存储有成员表,所述成员表包括所述Docker服务器集中各Docker服务器的标识信息、IP地址和资源占用率。5.根据权利要求4所述的方法,其特征在于,还包括: 所述第一 Docker服务器计算所述第一 Docker服务器的资源占用率; 所述第一 Docker服务器将所述第一 Docker服务器的标识信息、IP地址和资源占用率广播到所述Docker服务器集中,以使所述Docker服务器集中除所述第一Docker服务器之外的Docker服务器将所述第一 Docker服务器的标识信息、IP地址和资源占用率更新到所述成员表。6.一种服务器调用装置,其特征在于,包括: 接收模块,用于接收任务执行指令; 确定模块,用于根据其所属的Docker服务器集中各Docker服务器的资源占用率,确定目标Docker服务器; 发送模块,用于将所述任务执行指令发送给所述目标Docker服务器,以使所述目标Docker服务器执行所述任务执行指令,并将执行结果返回给所述第一 Docker服务器。7.根据权利要求6所述的服务器调用装置,其特征在于,所述Docker服务器集中各Docker服务器在同一个子网中。8.根据权利要求7所述的服务器调用装置,其特征在于,所述目标Docker服务器是所述Docker服务器集中资源占用率低于阈值的第二 Docker服务器;或者 所述目标Docker服务器是所述Docker服务器集中除所述第一 Docker服务器之外的Docker服务器。9.根据权利要求6-8任一项所述的服务器调用装置,其特征在于,所述第一Docker服务器存储有成员表,所述成员表包括所述Docker服务器集中各Docker服务器的标识信息、IP地址和资源占用率。10.根据权利要求9所述的服务器调用装置,其特征在于,还包括: 计算模块,用于计算所述第一 Docker服务器的资源占用率; 所述发送模块,还用于将所述第一Docker服务器的标识信息、IP地址和资源占用率广播到所述Docker服务器集中,以使所述Docker服务器集中除所述第一Docker服务器之外的Docker服务器将所述第一 Docker服务器的标识信息、IP地址和资源占用率更新到所述成员表。
【文档编号】H04L29/08GK106060127SQ201610350284
【公开日】2016年10月26日
【申请日】2016年5月24日
【发明人】田新雪, 马书惠
【申请人】中国联合网络通信集团有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1