CN116302356A - 容器的部署方法、装置、存储介质以及电子设备 - Google Patents

容器的部署方法、装置、存储介质以及电子设备 Download PDF

Info

Publication number
CN116302356A
CN116302356A CN202310309111.XA CN202310309111A CN116302356A CN 116302356 A CN116302356 A CN 116302356A CN 202310309111 A CN202310309111 A CN 202310309111A CN 116302356 A CN116302356 A CN 116302356A
Authority
CN
China
Prior art keywords
container
information
determining
physical machine
machine
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202310309111.XA
Other languages
English (en)
Inventor
林家雄
尹强
潘洪添
任玉泽
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Industrial and Commercial Bank of China Ltd ICBC
Original Assignee
Industrial and Commercial Bank of China Ltd ICBC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Industrial and Commercial Bank of China Ltd ICBC filed Critical Industrial and Commercial Bank of China Ltd ICBC
Priority to CN202310309111.XA priority Critical patent/CN116302356A/zh
Publication of CN116302356A publication Critical patent/CN116302356A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)

Abstract

本申请公开了一种容器的部署方法、装置、存储介质以及电子设备。涉及大数据领域。该方法包括:接收用户发送的应用请求,其中,应用请求用于请求生成容器;确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;根据容器类型和容器数量在M个空闲物理机中部署容器。通过本申请,解决了相关技术中通过人工部署容器的准确率和效率低的问题。

Description

容器的部署方法、装置、存储介质以及电子设备
技术领域
本申请涉及大数据领域,具体而言,涉及一种容器的部署方法、装置、存储介质以及电子设备。
背景技术
Docker容器是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。几乎没有性能开销,可以很容易地在机器和数据中心中运行。最重要的是,他们不依赖于任何语言、框架包括系统。
随着数据库容器化在企业中的应用范围逐步扩大,需要进行大量的容器部署,但是,目前搭建数据库容器,都需对每个数据库容器手工选择指定的宿主机,也即物理机进行搭建。
目前这种指定搭建方式,需考虑物理机所在的位置分布,以及对物理机的性能进行确定,从而根据物理机的性能和分布位置进行容器的搭建。由于当前选择搭建容器的物理机的时候,需要人工进行选择,从操作角度来说流程非常繁琐,且同时需要考虑物理机的剩余CPU、内存、存储等资源,再进行分配,容器部署方式相当复杂,并且人工确定部署方案的准确性较低,容易产生容器的异常部署现象发生。
针对相关技术中通过人工部署容器的准确率和效率低的问题,目前尚未提出有效的解决方案。
发明内容
本申请提供一种容器的部署方法、装置、存储介质以及电子设备,以解决相关技术中通过人工部署容器的准确率和效率低的问题。
根据本申请的一个方面,提供了一种容器的部署方法。该方法包括:接收用户发送的应用请求,其中,应用请求用于请求生成容器;确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;根据容器类型和容器数量在M个空闲物理机中部署容器。
可选地,确定应用请求指示的容器信息包括:确定应用请求指示的业务内容,并将业务内容输入预设表中,通过预设表得到业务内容的业务等级,其中,预设表中包括业务内容以及每个业务内容的业务等级;获取等级划分表,并从等级划分表中确定业务等级对应的容器类型,以及每个类型的容器对应的容器数量,得到容器信息,其中,等级划分表中包括业务等级,以及每个业务等级对应的容器信息。
可选地,物理机信息中包括剩余CPU容量、剩余内存容量和剩余磁盘量,根据目标机房信息中的每个物理机信息确定空闲物理机包括:获取应用请求指示生成的待搭建容器的CPU使用量,并将剩余CPU容量与CPU使用量相除,得到第一数量;获取待搭建容器的内存使用量,并将剩余内存容量与内存使用量相除,得到第二数量;获取待搭建容器的磁盘使用量,并将剩余磁盘量与磁盘使用量相除,得到第三数量;判断第一数量、第二数量和第三数量是否均大于等于1;在第一数量、第二数量或第三数量中的至少一个数量小于1的情况下,确定物理机为满负荷物理机;在第一数量、第二数量和第三数量均大于等于1的情况下,确定物理机为空闲物理机。
可选地,容器类型包括主容器和备用容器,根据容器类型和容器数量在M个空闲物理机中部署容器包括:获取每个空闲物理机中的第一数量、第二数量和第三数量,得到每个空闲物理机的属性数据集;获取每个属性数据集中的最小数据值,得到第一数据值集合,并确定第一数据值集合中的最大数据值,得到第二数据值;确定第二数据值所属的空闲物理机为第一物理机,并将容器信息中的主容器信息输入第一物理机中,通过第一物理机搭建主容器,其中,第一数据值集合由M个第一数据值组成;将容器数量减1,得到第四数量N,并从M个空闲物理机中的非第一物理机中随机选取N个物理机,得到N个第二物理机,其中,N为大于等于1的正整数;将容器信息中的备用容器信息输入N个第二物理机中,通过每个第二物理机搭建备用容器,得到N个备用容器。
可选地,在确定第二数据值所属的空闲物理机为第一物理机之后,该方法还包括:判断第一物理机中是否存在主容器;在第一物理机中存在主容器的情况下,重复执行从第一数据值集合中删除第二数据值,得到更新后的第一数据值集合,并在更新后的第一数据值集合中重新确定最大数据值,得到更新的第二数据值,并确定更新的第二数据值所属的第一物理机的步骤,直至更新的第二数据值所属的第一物理机中不存在主容器;在第一物理机中不存在主容器的情况下,执行将容器信息中的主容器信息输入第一物理机中,通过第一物理机搭建主容器的步骤。
可选地,在从M个空闲物理机中的非第一物理机中随机选取N个物理机,得到N个第二物理机之前,该方法还包括:判断M的数值是否大于等于N的数值;在M的数值小于N的数值的情况下,获取除目标机房信息之外的其余机房信息;从其余机房信息中获取任意机房信息,得到备用机房信息,并将N-M个备用容器在备用机房信息中的空闲物理机中进行搭建。
可选地,在确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机之后,该方法还包括:获取除目标机房信息之外的其余机房的机房信息,得到X个候选机房信息;确定每个候选机房信息的空闲物理机数量,得到X个候选数值;判断X个候选数值中是否存在大于M的数值;在X个候选数值中不存在大于M的情况下,执行根据容器类型和容器数量在M个空闲物理机中部署容器的步骤;在X个候选数值中存在大于M的情况下,确定X个候选数值中的最大候选数值所属的候选机房信息,得到替换机房信息,并将目标机房信息变更为替换机房信息。
根据本申请的另一方面,提供了一种容器的部署装置。该装置包括:接收单元,用于接收用户发送的应用请求,其中,应用请求用于请求生成容器;第一确定单元,用于确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;第二确定单元,用于确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;部署单元,用于根据容器类型和容器数量在M个空闲物理机中部署容器。
根据本发明实施例的另一方面,还提供了一种计算机存储介质,计算机存储介质用于存储程序,其中,程序运行时控制计算机存储介质所在的设备执行一种容器的部署方法。
根据本发明实施例的另一方面,还提供了一种电子设备,包含一个或多个处理器和存储器;存储器中存储有计算机可读指令,处理器用于运行计算机可读指令,其中,计算机可读指令运行时执行一种容器的部署方法。
通过本申请,采用以下步骤:接收用户发送的应用请求,其中,应用请求用于请求生成容器;确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;根据容器类型和容器数量在M个空闲物理机中部署容器。解决了相关技术中通过人工部署容器的准确率和效率低的问题。通过确定应用请求指示的机房信息、容器类型和容器数量,确定在机房中的多个物理机中进行容器部署的方式,并根据容器类型和容器数量在多个物理机中按照部署规则进行部署,通过计算每个物理机和容器之间的配置关系确定容器的部署方案,进而达到了提高容器部署的效率和准确率的效果。
附图说明
构成本申请的一部分的附图用来提供对本申请的进一步理解,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1是根据本申请实施例提供的容器的部署系统的示意图;
图2是根据本申请实施例提供的容器的部署方法的流程图;
图3是根据本申请实施例提供的容器的部署装置的示意图;
图4为根据本申请实施例提供的一种电子设备的示意图。
具体实施方式
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
为了使本技术领域的人员更好地理解本申请方案,下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分的实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本申请保护的范围。
需要说明的是,本申请的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本申请的实施例。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
需要说明的是,本公开所涉及的相关信息(包括但不限于用户设备信息、用户个人信息等)和数据(包括但不限于用于展示的数据、分析的数据等),均为经用户授权或者经过各方充分授权的信息和数据。例如,本系统和相关用户或机构间设置有接口,在获取相关信息之前,需要通过接口向前述的用户或机构发送获取请求,并在接收到前述的用户或机构反馈的同意信息后,获取相关信息。
需要说明的是,本公开所确定的容器的部署方法、装置、存储介质以及电子设备可用于大数据领域,也可用于除大数据领域之外的任意领域,本公开所确定的容器的部署方法、装置、存储介质以及电子设备的应用领域不做限定。
在本实施例中,如图1所示,以一种可选的容器的部署系统为执行主体执行前述容器的部署系统方法,该容器的部署系统至少包括:应用请求模组101、服务控制模组102、资源池103以及容器集群104。
其中,应用请求模组101负责应用提交数据库容器资源申请的地方,包括架构、分片数、容器CPU及内存规格、存储规格等信息。其中,CPU(Central Processing Unit中央处理器)。
服务控制模组102,负责接收应用请求后,根据应用的灾备等级决定主容器和备用容器的个数,再结合分片数算出需在各个机房搭建的容器节点数,获取需要部署的机房物理机资源清单(剩余CPU、内存、网络、存储)并筛选应用指定架构(x86/arm),确认资源后先分配每个分片的主容器,再分配每个分片的备用容器。
资源池103,负责管理物理机资源,包括CPU、内存、网络、磁盘存储等信息。
容器集群104,负责创建数据库容器,提供数据库服务。
根据本申请的实施例,提供了一种容器的部署方法。
图2是根据本申请实施例提供的容器的部署方法的流程图。如图2所示,该方法包括以下步骤:
步骤S201,接收用户发送的应用请求,其中,应用请求用于请求生成容器。
具体的,应用请求中可以包括用户想要创建的容器的规格,包括架构、分片数、容器CPU及内存规格、存储规格等信息,并根据容器规格以及该应用请求中的重要等级确定容器的生成和部署方案。
步骤S202,确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量。
具体的,在从应用请求中得到该请求的重要等级后,即可根据重要等级确定该请求所需要的容器数量,以及容器的部署要求,从而可以根据容器数量、部署要求以及容器规格确定部署容器的物理机。其中,容器类型包括每个重要等级下需要部署的容器的类型,例如,仅需要部署主容器,或是需要部署主容器和备用容器,以及每类容器的容器数量,例如,主容器需要部署一个,备用容器需要部署三个。
步骤S203,确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括A个物理机信息,A的值大于M的值。
具体的,在得到应用请求后,可以先确定机房中存在的物理机数量,得到A个物理机,根据应用请求指示的机房信息确定该机房中物理机信息,从而确定该机房中是否还可以在物理机中新建容器,因此,需要对每个物理机进行确认,从A个物理机中选择出可以进行容器部署的物理机,得到M个空闲物理机,并进一步的在该机房中无法进行容器部署的时候,选择其余机房进行协同部署,进而保证了应用请求的正常执行以及容器的正常使用。
步骤S204,根据容器类型和容器数量在M个空闲物理机中部署容器。
具体的,在确定了空闲物理机后,即可根据容器类型和容器数量将容器部署至物理机中,从而完成应用请求的容器部署。例如,在A机房中存在5台空闲物理机的情况下,在需要部署一个主容器和一个备用容器的情况下,即可将主容器部署在任意空闲物理机中,并将备用容器部署在其他4个空闲物理机中的任意一个物理机中,从而完成容器的部署工作。
本申请实施例提供的容器的部署方法,通过接收用户发送的应用请求,其中,应用请求用于请求生成容器;确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;根据容器类型和容器数量在M个空闲物理机中部署容器。解决了相关技术中通过人工部署容器的准确率和效率低的问题。通过确定应用请求指示的机房信息、容器类型和容器数量,确定在机房中的多个物理机中进行容器部署的方式,并根据容器类型和容器数量在多个物理机中按照部署规则进行部署,通过计算每个物理机和容器之间的配置关系确定容器的部署方案,进而达到了提高容器部署的效率和准确率的效果。
可选地,在本申请实施例提供的容器的部署方法中,确定应用请求指示的容器信息包括:确定应用请求指示的业务内容,并将业务内容输入预设表中,通过预设表得到业务内容的业务等级,其中,预设表中包括业务内容以及每个业务内容的业务等级;获取等级划分表,并从等级划分表中确定业务等级对应的容器类型,以及每个类型的容器对应的容器数量,得到容器信息,其中,等级划分表中包括业务等级,以及每个业务等级对应的容器信息。
具体的,表1为一种可选的业务等级和容器信息的对照表,如表1所示,在得到业务内容后,可以根据预设表确定该业务内容的业务等级,也即重要等级,并根据业务等级确定该等级下的容器类型和每个类型下的容器数量,进而保证容器部署方案可以满足业务内容的应用。
表1
业务等级 主容器数量 备用容器数量
1 1 1
2 1 1
3 1 2
4 1 3
5 1 4
可选地,在本申请实施例提供的容器的部署方法中,物理机信息中包括剩余CPU容量、剩余内存容量和剩余磁盘量,根据目标机房信息中的每个物理机信息确定空闲物理机包括:获取应用请求指示生成的待搭建容器的CPU使用量,并将剩余CPU容量与CPU使用量相除,得到第一数量;获取待搭建容器的内存使用量,并将剩余内存容量与内存使用量相除,得到第二数量;获取待搭建容器的磁盘使用量,并将剩余磁盘量与磁盘使用量相除,得到第三数量;判断第一数量、第二数量和第三数量是否均大于等于1;在第一数量、第二数量或第三数量中的至少一个数量小于1的情况下,确定物理机为满负荷物理机;在第一数量、第二数量和第三数量均大于等于1的情况下,确定物理机为空闲物理机。
具体的,在得到容器数量和容器类型后,可以获取容器的规格,包括:每个容器的CPU使用量、内存使用量、磁盘使用量等,此时,需要确定目标机房中的每个物理机在当前状态下的剩余CPU容量、剩余内存容量和剩余磁盘量,并依次将将剩余CPU容量与CPU使用量相除,得到第一数量,将剩余内存容量与内存使用量相除,得到第二数量,将剩余磁盘量与磁盘使用量相除,得到第三数量,从而通过计算容器与物理机的剩余系统配置之间的关系,确定物理机是否可以进行容器的安装。
进一步的,在第一数量、第二数量和第三数量均大于等于1的情况下,表征该物理机中可以部署一个容器,则将该物理机即为空闲物理机。
可选地,在本申请实施例提供的容器的部署方法中,容器类型包括主容器和备用容器,根据容器类型和容器数量在M个空闲物理机中部署容器包括:获取每个空闲物理机中的第一数量、第二数量和第三数量,得到每个空闲物理机的属性数据集;获取每个属性数据集中的最小数据值,得到第一数据值集合,并确定第一数据值集合中的最大数据值,得到第二数据值;确定第二数据值所属的空闲物理机为第一物理机,并将容器信息中的主容器信息输入第一物理机中,通过第一物理机搭建主容器,其中,第一数据值集合由M个第一数据值组成;将容器数量减1,得到第四数量N,并从M个空闲物理机中的非第一物理机中随机选取N个物理机,得到N个第二物理机,其中,N为大于等于1的正整数;将容器信息中的备用容器信息输入N个第二物理机中,通过每个第二物理机搭建备用容器,得到N个备用容器。
具体的,在得到每个空闲物理机的第一数量、第二数量和第三数量后,需要确定第一数量、第二数量和第三数量中的最小值,从而得到每个空闲物理机中所能部署的最大容器数量,并从M个空闲物理机中确定最大容器数量最大的物理机,并将主容器部署在该物理机中,从而保证主容器出现异常的概率最小。
进一步的,在完成主容器的部署后,需要确定该主容器对应的N个备用容器的部署物理机,此时,需要从M个空闲物理机中确定第一物理机,也即部署该应用请求的主容器的物理机,并在除去该第一物理机之外的M-1个空闲物理机中随机选取N个物理机,也即第四数量的空闲物理机,将选取出的每个空闲物理机中部署一个备用容器,从而在目标机房中的多个物理机中完成容器的部署。
例如,应用请求中需要部署1个主容器和2个备用容器,目标机房中存在5个空闲物理机,主容器部署在2号空闲物理机中,则2个备用容器需要部署在除了2号空闲物理机之外的其余4个空闲物理机中的任意两个中,从而完成容器部署。
可选地,在本申请实施例提供的容器的部署方法中,在确定第二数据值所属的空闲物理机为第一物理机之后,该方法还包括:判断第一物理机中是否存在主容器;在第一物理机中存在主容器的情况下,重复执行从第一数据值集合中删除第二数据值,得到更新后的第一数据值集合,并在更新后的第一数据值集合中重新确定最大数据值,得到更新的第二数据值,并确定更新的第二数据值所属的第一物理机的步骤,直至更新的第二数据值所属的第一物理机中不存在主容器;在第一物理机中不存在主容器的情况下,执行将容器信息中的主容器信息输入第一物理机中,通过第一物理机搭建主容器的步骤。
具体的,在确定第一物理机的时候,需要确定第一物理机中是否已经存在其他应用请求部署的主容器,在第一物理机中已经部署主容器的情况下,本应用请求的主容器则不能部署在该第一物理机中,此时,需要从M个空闲物理机中将该物理机去除,并从剩余的M-1个空闲物理机中重新确定第一物理机,从而保证每个物理机中只部署一个主容器。
可选地,在本申请实施例提供的容器的部署方法中,在从M个空闲物理机中的非第一物理机中随机选取N个物理机,得到N个第二物理机之前,方法还包括:判断M的数值是否大于N的数值;在M的数值小于等于N的数值的情况下,获取除目标机房信息之外的其余机房信息;从其余机房信息中获取任意机房信息,得到备用机房信息,并将N-M个备用容器在备用机房信息中的空闲物理机中进行搭建。
具体的,在确定了备用容器的第四数量N后,需要根据目标机房中的空闲物理机的总数确定是否存在足够多的空闲物理机,此时,需要将空闲物理机的数量M与第四数量N进行对比,在M大于等于N的情况下,表征目标机房中的空闲物理机可以进行此次容器部署操作,则进行部署,在M小于N的情况下,表征目标机房中的空闲物理机的数量小于需要部署的容器的数量,此时,目标机房中的全部空闲物理机均需要部署容器,并且还需要在其余机房中将无法在目标机房中进行部署的容器部署在其他机房中,从而保证容器的正常部署操作。
可选地,在本申请实施例提供的容器的部署方法中,在确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机之后,该方法还包括:获取除目标机房信息之外的其余机房的机房信息,得到X个候选机房信息;确定每个候选机房信息的空闲物理机数量,得到X个候选数值;判断X个候选数值中是否存在大于M的数值;在X个候选数值中不存在大于M的情况下,执行根据容器类型和容器数量在M个空闲物理机中部署容器的步骤;在X个候选数值中存在大于M的情况下,确定X个候选数值中的最大候选数值所属的候选机房信息,得到替换机房信息,并将目标机房信息变更为替换机房信息。
具体的,在确定目标机房之后,还可以确定除目标机房信息之外的其余机房的机房信息,从而可以根据其余机房的机房信息判断是否存在比目标机房更适合创建容器的机房。
在得到其余机房的时候,可以确定每个机房的空闲物理机数量,并从中确定最大空闲数量对应的机房信息,在该机房为目标机房的情况下,可以进行后续操作,在该机房不是目标机房,而是其他机房的情况下,可以将最大空闲数量对应的机房确定为目标机房,从而提高容器部署的效果。
需要说明的是,在附图的流程图示出的步骤可以在诸如一组计算机可执行指令的计算机系统中执行,并且,虽然在流程图中示出了逻辑顺序,但是在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤。
本申请实施例还提供了一种容器的部署装置,需要说明的是,本申请实施例的容器的部署装置可以用于执行本申请实施例所提供的用于容器的部署方法。以下对本申请实施例提供的容器的部署装置进行介绍。
图3是根据本申请实施例提供的容器的部署装置的示意图。如图3所示,该装置包括:接收单元31,第一确定单元32,第二确定单元33,部署单元34。
接收单元31,用于接收用户发送的应用请求,其中,应用请求用于请求生成容器。
第一确定单元32,用于确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量。
第二确定单元33,用于确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息。
部署单元34,用于根据容器类型和容器数量在M个空闲物理机中部署容器。
本申请实施例提供的容器的部署装置,通过接收单元31接收用户发送的应用请求,其中,应用请求用于请求生成容器;第一确定单元32确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;第二确定单元33确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;部署单元34根据容器类型和容器数量在M个空闲物理机中部署容器。解决了相关技术中通过人工部署容器的准确率和效率低的问题。通过确定应用请求指示的机房信息、容器类型和容器数量,确定在机房中的多个物理机中进行容器部署的方式,并根据容器类型和容器数量在多个物理机中按照部署规则进行部署,通过计算每个物理机和容器之间的配置关系确定容器的部署方案,进而达到了提高容器部署的效率和准确率的效果。
可选地,在本申请实施例提供的容器的部署装置中,第一确定单元32包括:第一确定模块,用于确定应用请求指示的业务内容,并将业务内容输入预设表中,通过预设表得到业务内容的业务等级,其中,预设表中包括业务内容以及每个业务内容的业务等级;第一获取模块,用于获取等级划分表,并从等级划分表中确定业务等级对应的容器类型,以及每个类型的容器对应的容器数量,得到容器信息,其中,等级划分表中包括业务等级,以及每个业务等级对应的容器信息。
可选地,在本申请实施例提供的容器的部署装置中,物理机信息中包括剩余CPU容量、剩余内存容量和剩余磁盘量,第二确定单元33包括:第一计算模块,用于获取应用请求指示生成的待搭建容器的CPU使用量,并将剩余CPU容量与CPU使用量相除,得到第一数量;第二计算模块,用于获取待搭建容器的内存使用量,并将剩余内存容量与内存使用量相除,得到第二数量;第三计算模块,用于获取待搭建容器的磁盘使用量,并将剩余磁盘量与磁盘使用量相除,得到第三数量;判断模块,用于判断第一数量、第二数量和第三数量是否均大于等于1;第二确定模块,用于在第一数量、第二数量或第三数量中的至少一个数量小于1的情况下,确定物理机为满负荷物理机;第三确定模块,用于在第一数量、第二数量和第三数量均大于等于1的情况下,确定物理机为空闲物理机。
可选地,在本申请实施例提供的容器的部署装置中,容器类型包括主容器和备用容器,部署单元34包括:第二获取模块,用于获取每个空闲物理机中的第一数量、第二数量和第三数量,得到每个空闲物理机的属性数据集;第三获取模块,用于获取每个属性数据集中的最小数据值,得到第一数据值集合,并确定第一数据值集合中的最大数据值,得到第二数据值;第四确定模块,用于确定第二数据值所属的空闲物理机为第一物理机,并将容器信息中的主容器信息输入第一物理机中,通过第一物理机搭建主容器,其中,第一数据值集合由M个第一数据值组成;选取模块,用于将容器数量减1,得到第四数量N,并从M个空闲物理机中的非第一物理机中随机选取N个物理机,得到N个第二物理机,其中,N为大于等于1的正整数;输入模块,用于将容器信息中的备用容器信息输入N个第二物理机中,通过每个第二物理机搭建备用容器,得到N个备用容器。
可选地,在本申请实施例提供的容器的部署装置中,该装置还包括:第一判断单元,用于判断第一物理机中是否存在主容器;第一执行单元,用于在第一物理机中存在主容器的情况下,重复执行从第一数据值集合中删除第二数据值,得到更新后的第一数据值集合,并在更新后的第一数据值集合中重新确定最大数据值,得到更新的第二数据值,并确定更新的第二数据值所属的第一物理机的步骤,直至更新的第二数据值所属的第一物理机中不存在主容器;第二执行单元,用于在第一物理机中不存在主容器的情况下,执行将容器信息中的主容器信息输入第一物理机中,通过第一物理机搭建主容器的步骤。
可选地,在本申请实施例提供的容器的部署装置中,该装置还包括:第二判断单元,用于判断M的数值是否大于等于N的数值;计算单元,用于在M的数值小于N的数值的情况下,获取除目标机房信息之外的其余机房信息;第一获取单元,用于从其余机房信息中获取任意机房信息,得到备用机房信息,并将N-M个备用容器在备用机房信息中的空闲物理机中进行搭建。
可选地,在本申请实施例提供的容器的部署装置中,该装置还包括:第二获取单元,用于获取除目标机房信息之外的其余机房的机房信息,得到X个候选机房信息;第四确定单元,用于确定每个候选机房信息的空闲物理机数量,得到X个候选数值;第三判断单元,用于判断X个候选数值中是否存在大于M的数值;第三执行单元,用于在X个候选数值中不存在大于M的情况下,执行根据容器类型和容器数量在M个空闲物理机中部署容器的步骤;第五确定单元,用于在X个候选数值中存在大于M的情况下,确定X个候选数值中的最大候选数值所属的候选机房信息,得到替换机房信息,并将目标机房信息变更为替换机房信息。
上述容器的部署装置包括处理器和存储器,上述接收单元31,第一确定单元32,第二确定单元33,部署单元34等均作为程序单元存储在存储器中,由处理器执行存储在存储器中的上述程序单元来实现相应的功能。
处理器中包含内核,由内核去存储器中调取相应的程序单元。内核可以设置一个或以上,通过调整内核参数来解决了相关技术中通过人工部署容器的准确率和效率低的问题。
存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM),存储器包括至少一个存储芯片。
本发明实施例提供了一种计算机可读存储介质,其上存储有程序,该程序被处理器执行时实现所述容器的部署方法。
本发明实施例提供了一种处理器,所述处理器用于运行程序,其中,所述程序运行时执行所述容器的部署方法。
如图4所示,本发明实施例提供了一种电子设备,电子设备40包括处理器、存储器及存储在存储器上并可在处理器上运行的程序,处理器执行程序时实现以下步骤:接收用户发送的应用请求,其中,应用请求用于请求生成容器;确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;根据容器类型和容器数量在M个空闲物理机中部署容器。本文中的设备可以是服务器、PC、PAD、手机等。
本申请还提供了一种计算机程序产品,当在数据处理设备上执行时,适于执行初始化有如下方法步骤的程序:接收用户发送的应用请求,其中,应用请求用于请求生成容器;确定应用请求指示的容器信息,其中,容器信息中包括容器类型和容器数量;确定应用请求指示的目标机房信息,根据目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中,目标机房信息中包括多个物理机信息;根据容器类型和容器数量在M个空闲物理机中部署容器。
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。存储器是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括要素的过程、方法、商品或者设备中还存在另外的相同要素。
以上仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。

Claims (10)

1.一种容器的部署方法,其特征在于,包括:
接收用户发送的应用请求,其中,所述应用请求用于请求生成容器;
确定所述应用请求指示的容器信息,其中,所述容器信息中包括容器类型和容器数量;
确定所述应用请求指示的目标机房信息,根据所述目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机,其中M大于等于1;
根据所述容器类型和所述容器数量在所述M个空闲物理机中部署容器。
2.根据权利要求1所述的方法,其特征在于,确定所述应用请求指示的容器信息包括:
确定所述应用请求指示的业务内容,并将所述业务内容输入预设表中,通过所述预设表得到所述业务内容的业务等级,其中,所述预设表中包括业务内容以及每个业务内容的业务等级;
获取等级划分表,并从所述等级划分表中确定所述业务等级对应的容器类型,以及每个类型的容器对应的容器数量,得到所述容器信息,其中,所述等级划分表中包括业务等级,以及每个业务等级对应的容器信息。
3.根据权利要求1所述的方法,其特征在于,所述物理机信息中包括剩余CPU容量、剩余内存容量和剩余磁盘量,根据所述目标机房信息中的每个物理机信息确定空闲物理机包括:
获取所述应用请求指示生成的待搭建容器的CPU使用量,并将所述剩余CPU容量与所述CPU使用量相除,得到第一数量;
获取待搭建容器的内存使用量,并将所述剩余内存容量与所述内存使用量相除,得到第二数量;
获取待搭建容器的磁盘使用量,并将所述剩余磁盘量与所述磁盘使用量相除,得到第三数量;
判断所述第一数量、所述第二数量和所述第三数量是否均大于等于1;
在所述第一数量、所述第二数量或所述第三数量中的至少一个数量小于1的情况下,确定所述物理机为满负荷物理机;
在所述第一数量、所述第二数量和所述第三数量均大于等于1的情况下,确定所述物理机为所述空闲物理机。
4.根据权利要求3所述的方法,其特征在于,所述容器类型包括主容器和备用容器,
根据所述容器类型和所述容器数量在所述M个空闲物理机中部署容器包括:
获取每个空闲物理机中的所述第一数量、所述第二数量和所述第三数量,得到每个空闲物理机的属性数据集;
获取每个属性数据集中的最小数据值,得到第一数据值集合,并确定所述第一数据值集合中的最大数据值,得到第二数据值,其中,所述第一数据值集合由M个第一数据值组成;
确定所述第二数据值所属的空闲物理机为第一物理机,并将所述容器信息中的主容器信息输入所述第一物理机中,通过所述第一物理机搭建主容器;
将所述容器数量减1,得到第四数量N,并从所述M个空闲物理机中的非第一物理机中随机选取N个物理机,得到N个第二物理机,其中,N为大于等于1的正整数;
将所述容器信息中的备用容器信息输入所述N个第二物理机中,通过每个第二物理机搭建备用容器,得到N个备用容器。
5.根据权利要求4所述的方法,其特征在于,在确定所述第二数据值所属的空闲物理机为第一物理机之后,所述方法还包括:
判断所述第一物理机中是否存在主容器;
在所述第一物理机中存在所述主容器的情况下,重复执行从所述第一数据值集合中删除所述第二数据值,得到更新后的第一数据值集合,并在所述更新后的第一数据值集合中重新确定最大数据值,得到更新的第二数据值,并确定所述更新的第二数据值所属的第一物理机的步骤,直至更新的第二数据值所属的第一物理机中不存在主容器;
在所述第一物理机中不存在所述主容器的情况下,执行所述将所述容器信息中的主容器信息输入所述第一物理机中,通过所述第一物理机搭建主容器的步骤。
6.根据权利要求4所述的方法,其特征在于,在从所述M个空闲物理机中的非第一物理机中随机选取N个物理机,得到N个第二物理机之前,所述方法还包括:
判断M的数值是否大于等于N的数值;
在M的数值小于N的数值的情况下,获取除所述目标机房信息之外的其余机房信息;
从所述其余机房信息中获取任意机房信息,得到备用机房信息,并将N-M个备用容器在所述备用机房信息中的空闲物理机中进行搭建。
7.根据权利要求1所述的方法,其特征在于,在确定所述应用请求指示的目标机房信息,根据所述目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机之后,所述方法还包括:
获取除所述目标机房信息之外的其余机房的机房信息,得到X个候选机房信息;
确定每个候选机房信息的空闲物理机数量,得到X个候选数值;
判断所述X个候选数值中是否存在大于M的数值;
在所述X个候选数值中不存在大于M的情况下,执行所述根据所述容器类型和所述容器数量在所述M个空闲物理机中部署容器的步骤;
在所述X个候选数值中存在大于M的情况下,确定所述X个候选数值中的最大候选数值所属的候选机房信息,得到替换机房信息,并将所述目标机房信息变更为所述替换机房信息。
8.一种容器的部署装置,其特征在于,包括:
接收单元,用于接收用户发送的应用请求,其中,所述应用请求用于请求生成容器;
第一确定单元,用于确定所述应用请求指示的容器信息,其中,所述容器信息中包括容器类型和容器数量;
第二确定单元,用于确定所述应用请求指示的目标机房信息,根据所述目标机房信息中的每个物理机信息确定空闲物理机,得到M个空闲物理机;
部署单元,用于根据所述容器类型和所述容器数量在所述M个空闲物理机中部署容器。
9.一种计算机存储介质,其特征在于,所述计算机存储介质用于存储程序,其中,所述程序运行时控制所述计算机存储介质所在的设备执行权利要求1至7中任意一项所述的容器的部署方法。
10.一种电子设备,其特征在于,包括一个或多个处理器和存储器,所述存储器用于存储一个或多个程序,其中,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现权利要求1至7中任意一项所述的容器的部署方法。
CN202310309111.XA 2023-03-27 2023-03-27 容器的部署方法、装置、存储介质以及电子设备 Pending CN116302356A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310309111.XA CN116302356A (zh) 2023-03-27 2023-03-27 容器的部署方法、装置、存储介质以及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310309111.XA CN116302356A (zh) 2023-03-27 2023-03-27 容器的部署方法、装置、存储介质以及电子设备

Publications (1)

Publication Number Publication Date
CN116302356A true CN116302356A (zh) 2023-06-23

Family

ID=86795722

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310309111.XA Pending CN116302356A (zh) 2023-03-27 2023-03-27 容器的部署方法、装置、存储介质以及电子设备

Country Status (1)

Country Link
CN (1) CN116302356A (zh)

Similar Documents

Publication Publication Date Title
US10635664B2 (en) Map-reduce job virtualization
CN110287197B (zh) 一种数据存储方法、迁移方法及装置
CN106407207B (zh) 一种实时新增数据更新方法和装置
US11698817B2 (en) Application link resource scaling method, apparatus, and system based on concurrent stress testing of plural application links
US10356150B1 (en) Automated repartitioning of streaming data
US20130227116A1 (en) Determining optimal component location in a networked computing environment
US20180113748A1 (en) Automated configuration of virtual infrastructure
US10680975B2 (en) Method of dynamic resource allocation for public clouds
CN104113576A (zh) 一种客户端的更新方法及装置
US20220329651A1 (en) Apparatus for container orchestration in geographically distributed multi-cloud environment and method using the same
CN110737717B (zh) 一种数据库迁移方法及装置
CN108241531A (zh) 一种在集群中为虚拟机分配资源的方法和装置
CN110659296B (zh) 存储方法、装置、设备以及计算机可读介质
CN110928941B (zh) 一种数据分片抽取方法及装置
CN116594734A (zh) 容器迁移方法、装置、存储介质及电子设备
US10387578B1 (en) Utilization limiting for nested object queries
CN106888244B (zh) 一种业务处理方法及装置
US9641384B1 (en) Automated management of computing instance launch times
CN116302356A (zh) 容器的部署方法、装置、存储介质以及电子设备
CN115827028A (zh) 系统的升级方法、装置、存储介质以及电子设备
CN115328608A (zh) 一种Kubernetes容器垂直伸缩调节方法和装置
CN110059075B (zh) 一种数据库迁移的方法、装置、设备及计算机可读介质
US10397312B2 (en) Automated server deployment platform
CN116382736A (zh) 应用的升级方法、装置、存储介质及电子设备
CN110928673A (zh) 任务的分配方法及装置

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination