CN113741908A - 高可用性部署方法、装置、电子装置和存储介质 - Google Patents

高可用性部署方法、装置、电子装置和存储介质 Download PDF

Info

Publication number
CN113741908A
CN113741908A CN202110981539.XA CN202110981539A CN113741908A CN 113741908 A CN113741908 A CN 113741908A CN 202110981539 A CN202110981539 A CN 202110981539A CN 113741908 A CN113741908 A CN 113741908A
Authority
CN
China
Prior art keywords
virtual machine
deployment
host
availability
database
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.)
Withdrawn
Application number
CN202110981539.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.)
DBAPPSecurity Co Ltd
Original Assignee
DBAPPSecurity Co Ltd
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 DBAPPSecurity Co Ltd filed Critical DBAPPSecurity Co Ltd
Priority to CN202110981539.XA priority Critical patent/CN113741908A/zh
Publication of CN113741908A publication Critical patent/CN113741908A/zh
Withdrawn legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • 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
    • 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
    • G06F2009/45562Creating, deleting, cloning virtual machine instances
    • 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
    • G06F2009/45595Network integration; Enabling network access in virtual machine instances

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

本申请涉及一种高可用性部署方法、装置、电子装置和存储介质。其中,该高可用性部署方法包括:获取虚拟机镜像文件,其中,虚拟机镜像文件用于创建虚拟机,虚拟机安装有预设单体应用、预设单体应用对应的中间件以及高可用性部署程序,其中,中间件包括以下至少之一:数据库功能模块、缓存功能模块;基于虚拟机镜像文件,创建虚拟机,并在虚拟机启动时执行高可用性部署程序;响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署。通过本申请,解决了相关技术中软件部署复杂的问题,简化了软件部署。

Description

高可用性部署方法、装置、电子装置和存储介质
技术领域
本申请涉及计算机软件部署领域,特别是涉及高可用性部署方法、装置、电子装置和存储介质。
背景技术
现互联网上还存在很多单体应用。单体应用便于共享、测试、部署,但是存在不支持高可用场景,一但单点故障直接影响到服务提供。
在现有技术中存在基于ansible的自动化部署业务***高可用集群的方式,该方式主要是依赖ansible(自动化运维工具)软件并需要准备相关配置脚本、操作复杂而且面向实施人员,并且仍需要在每台服务器上安装好业务***。
针对相关技术中存在软件部署复杂的问题,目前还没有提出有效的解决方案。
发明内容
在本实施例中提供了一种高可用性部署方法、装置、电子装置和存储介质,以解决相关技术中软件部署复杂的问题。
第一个方面,在本实施例中提供了一种高可用性部署方法,包括:
获取虚拟机镜像文件,其中,所述虚拟机镜像文件用于创建虚拟机,所述虚拟机安装有预设单体应用、所述预设单体应用对应的中间件以及高可用性部署程序,其中,所述中间件包括以下至少之一:数据库功能模块、缓存功能模块;
基于所述虚拟机镜像文件,创建所述虚拟机,并在所述虚拟机启动时执行所述高可用性部署程序;
响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署。
在其中的一些实施例中,所述高可用性部署程序包括:数据库部署程序;响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署包括:
响应于所述数据库部署程序的执行,配置所述虚拟机中SQL数据库文件;
获取主机中SQL数据库文件的binlog文件名称和位置;
基于所述主机中SQL数据库文件的binlog文件名称和位置,配置主从同步服务;
执行所述主从同步服务,在所述虚拟机中进行SQL数据库的高可用性部署。
在其中的一些实施例中,所述高可用性部署程序包括:缓存部署程序;响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署包括:
响应于所述数据库部署程序的执行,配置所述虚拟机中Redis缓存文件;
获取主机中Redis缓存文件的binlog文件名称和位置;
基于所述主机中Redis缓存文件的binlog文件名称和位置,配置主从同步服务;
执行所述主从同步服务,在所述虚拟机中进行Redis缓存的高可用性部署。
在其中的一些实施例中,在响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署之后,所述方法还包括:
检测主机中的数据库的数据与所述虚拟机进行高可用性部署之后的数据库的数据是否相同;
在检测所述主机中的数据库的数据与所述虚拟机进行高可用性部署之后的数据库的数据不相同的情况下,响应于所述高可用性部署程序的执行,将所述主机中的数据库的数据同步到所述虚拟机中的数据库。
在其中的一些实施例中,在响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署之前,所述方法还包括:
获取主机的主机IP地址;
将所述主机IP地址虚拟成虚拟IP地址,并将所述虚拟IP地址挂载到正在运行的所述主机或虚拟机上。
在其中的一些实施例中,将所述主机IP地址虚拟成虚拟IP地址,并将所述虚拟IP地址挂载到正在运行的所述主机或虚拟机上包括:
通过keepalive服务监听所述主机或所述虚拟机的是否正在运行;
在监听所述主机正在运行的情况下,将所述虚拟IP地址挂载到所述主机上,或,在监听到所述虚拟机正在运行的情况下,将所述虚拟IP地址挂载到虚拟机上。
在其中的一些实施例中,在通过keepalive服务将所述主机IP虚拟成所述虚拟IP地址之前,所述方法还包括:
在所述主机和所述虚拟机中配置所述keepalive服务。
第二个方面,在本实施例中提供了一种高可用性部署装置,包括:
第一获取模块,用于获取虚拟机镜像文件,其中,所述虚拟机镜像文件用于创建虚拟机,所述虚拟机安装有预设单体应用、所述预设单体应用对应的中间件以及高可用性部署程序,其中,所述中间件包括以下至少之一:数据库功能模块、缓存功能模块;
创建模块,用于基于所述虚拟机镜像文件,创建所述虚拟机,并在所述虚拟机启动时执行所述高可用性部署程序;
部署模块,用于响应于所述数据库部署程序的执行,基于所述预设单体应用以及所述数据库功能模块进行所述预设单体应用中的SQL数据库高可用性部署。
第三个方面,在本实施例中提供了一种电子装置,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现上述第一个方面所述的高可用性部署方法。
第四个方面,在本实施例中提供了一种存储介质,其上存储有计算机程序,该程序被处理器执行时实现上述第一个方面的高可用性部署方法。
与相关技术相比,在本实施例中提供的高可用性部署方法、装置、电子装置和存储介质,通过获取虚拟机镜像文件,其中,虚拟机镜像文件用于创建虚拟机,虚拟机安装有预设单体应用、预设单体应用对应的中间件以及高可用性部署程序,其中,中间件包括以下至少之一:数据库功能模块、缓存功能模块;基于虚拟机镜像文件,创建虚拟机,并在虚拟机启动时执行高可用性部署程序;响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署的方式,解决了相关技术中软件部署复杂的问题,简化了软件部署。
申请的一个或多个实施例的细节在以下附图和描述中提出,以使本申请的其他特征、目的和优点更加简明易懂。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1是本实施例的高可用性部署方法的终端的硬件结构框图;
图2是本实施例的高可用性部署方法的流程图;
图3是本实施例的高可用部署架构示意图;
图4是本优选实施例的高可用部署方法的流程图;
图5是本实施例的高可用性部署装置的结构框图。
具体实施方式
为更清楚地理解本申请的目的、技术方案和优点,下面结合附图和实施例,对本申请进行了描述和说明。
除另作定义外,本申请所涉及的技术术语或者科学术语应具有本申请所属技术领域具备一般技能的人所理解的一般含义。在本申请中的“一”、“一个”、“一种”、“该”、“这些”等类似的词并不表示数量上的限制,它们可以是单数或者复数。在本申请中所涉及的术语“包括”、“包含”、“具有”及其任何变体,其目的是涵盖不排他的包含;例如,包含一系列步骤或模块(单元)的过程、方法和***、产品或设备并未限定于列出的步骤或模块(单元),而可包括未列出的步骤或模块(单元),或者可包括这些过程、方法、产品或设备固有的其他步骤或模块(单元)。在本申请中所涉及的“连接”、“相连”、“耦接”等类似的词语并不限定于物理的或机械连接,而可以包括电气连接,无论是直接连接还是间接连接。在本申请中所涉及的“多个”是指两个或两个以上。“和/或”描述关联对象的关联关系,表示可以存在三种关系,例如,“A和/或B”可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。通常情况下,字符“/”表示前后关联的对象是一种“或”的关系。在本申请中所涉及的术语“第一”、“第二”、“第三”等,只是对相似对象进行区分,并不代表针对对象的特定排序。
在本实施例中提供的方法实施例可以在终端、计算机或者类似的运算装置中执行。比如在终端上运行,图1是本实施例的高可用性部署方法的终端的硬件结构框图。如图1所示,终端可以包括一个或多个(图1中仅示出一个)处理器102和用于存储数据的存储器104,其中,处理器102可以包括但不限于微处理器MCU或可编程逻辑器件FPGA等的处理装置。上述终端还可以包括用于通信功能的传输设备106以及输入输出设备108。本领域普通技术人员可以理解,图1所示的结构仅为示意,其并不对上述终端的结构造成限制。例如,终端还可包括比图1中所示更多或者更少的组件,或者具有与图1所示出的不同配置。
存储器104可用于存储计算机程序,例如,应用软件的软件程序以及模块,如在本实施例中的高可用性部署方法对应的计算机程序,处理器102通过运行存储在存储器104内的计算机程序,从而执行各种功能应用以及数据处理,即实现上述的方法。存储器104可包括高速随机存储器,还可包括非易失性存储器,如一个或者多个磁性存储装置、闪存、或者其他非易失性固态存储器。在一些实例中,存储器104可进一步包括相对于处理器102远程设置的存储器,这些远程存储器可以通过网络连接至终端。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
传输设备106用于经由一个网络接收或者发送数据。上述的网络包括终端的通信供应商提供的无线网络。在一个实例中,传输设备106包括一个网络适配器(NetworkInterface Controller,简称为NIC),其可通过基站与其他网络设备相连从而可与互联网进行通讯。在一个实例中,传输设备106可以为射频(Radio Frequency,简称为RF)模块,其用于通过无线方式与互联网进行通讯。
在本实施例中提供了一种高可用性部署方法,图2是本实施例的高可用性部署方法的流程图,如图2所示,该流程包括如下步骤:
步骤S201,获取虚拟机镜像文件,其中,虚拟机镜像文件用于创建虚拟机,虚拟机安装有预设单体应用、预设单体应用对应的中间件以及高可用性部署程序,其中,中间件包括以下至少之一:数据库功能模块、缓存功能模块。
在本步骤中,可以将主机中的预设单体应用、预设单体应用对应的中间件以及高可用性部署程序打包成虚拟机镜像文件,便于在进行高可用性部署时直接根据该虚拟机镜像文件来进行,节省了部署流程。
需要说明的是,单体应用,是指一个war包包含了项目的所有功能,其优点是容易部署,容易运行测试;其缺点是可靠性差等,因此需要实现高可用性。
步骤S202,基于虚拟机镜像文件,创建虚拟机,并在虚拟机启动时执行高可用性部署程序。
在本步骤中,基于虚拟机镜像文件创建虚拟机的方式,该虚拟机可以作为主机的备用从机,即在主机出现故障不能运行时,将该虚拟机作为主机使用,以实现高可用性部署。
步骤S203,响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署。
在本步骤中,根据高可用性部署程序在执行中给出的指令,对单体应用和中间件进行处理,以实现高可用性部署。
基于步骤S201至步骤S203,通过根据高可用性部署程序在执行中给出的指令,对单体应用和中间件进行处理,以实现高可用性部署的方式,实现了单体应用在主机和虚拟机之间的高可用性部署,避免相关技术中单体应用的部署依赖ansible(自动化运维工具)软件并需要准备相关配置脚本、操作复杂而且面向实施人员,并且仍需要在每台服务器上安装好业务***,而造成软件部署复杂的问题,简化了软件部署。
本实施例中的该虚拟机镜像文件可以存储在云平台上;也可以直接传输给客户端,便于客户端使用进行高可用方案的部署。
虚拟机镜像文件在云平台上时,通过web服务提供的一键配置按钮,向后端服务器发起高可用配置请求,后端服务执行以下过程:通过云平台接口,根据预先打包的镜像文件,在云平台上自动创建一台新的虚拟机;执行虚拟机中的自动部署服务,并自动部署服务构建成虚拟机,进而完成高可用性自动部署。
虚拟机镜像文件直接传输给客户端时,客户端首先根据镜像文件创建虚拟机,然后执行虚拟机中的自动部署服务,并自动部署服务构建成虚拟机,完成高可用性自动部署。
在其中的一些实施例中,高可用性部署程序包括:数据库部署程序;响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署包括:响应于数据库部署程序的执行,配置虚拟机中SQL数据库文件;获取主机中SQL数据库文件的binlog文件名称和位置;基于主机中SQL数据库文件的binlog文件名称和位置,配置主从同步服务;执行主从同步服务,在虚拟机中进行SQL数据库的高可用性部署。
在本实施例中,通过执行主从同步服务,在虚拟机中进行SQL数据库的高可用性部署的方式,实现了SQL数据库在主机和虚拟机之间的高可用性部署。
在其中的一些实施例中,高可用性部署程序包括:缓存部署程序;响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署包括:响应于数据库部署程序的执行,配置虚拟机中Redis缓存文件;获取主机中Redis缓存文件的binlog文件名称和位置;基于主机中Redis缓存文件的binlog文件名称和位置,配置主从同步服务;执行主从同步服务,在虚拟机中进行Redis缓存的高可用性部署。
在本实施例中,通过执行主从同步服务,在虚拟机中进行Redis缓存的高可用性部署的方式,实现了Redis缓存在主机和虚拟机之间的高可用性部署。
在其中的一些实施例中,在响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署之后,还可以检测主机中的数据库的数据与虚拟机进行高可用性部署之后的数据库的数据是否相同;在检测主机中的数据库的数据与虚拟机进行高可用性部署之后的数据库的数据不相同的情况下,响应于高可用性部署程序的执行,将主机中的数据库的数据同步到虚拟机中的数据库。
虚拟机镜像文件中的数据库信息可能是空的或者非最新的数据库,因此在本实施例中,通过在检测主机中的数据库的数据与虚拟机进行高可用性部署之后的数据库的数据不相同的情况下,响应于高可用性部署程序的执行,将主机中的数据库的数据同步到虚拟机中的数据库的方式,实现了主机与虚拟机之间的同步服务。
在其中的一些实施例中,在响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署之前,还可以获取主机的主机IP地址;将主机IP地址虚拟成虚拟IP地址,并将虚拟IP地址挂载到正在运行的主机或虚拟机上。
在本实施例中,由于主机的单体应用对外提供服务时,客户端能够看到的是虚拟IP地址(VIP),因此,将原来的主机IP地址作为VIP可以保证在配置高可用性前后,客户端始终使用的单体应用的主机IP地址不变,做到用户无感。
需要说明的是,虚拟IP地址(VIP),就是一个未分配给真实主机的IP地址,也就是说对外提供数据库服务器的主机除了有一个真实IP地址外还有一个虚IP地址,使用这两个IP地址中的任意一个都可以连接到这台主机,所有项目中数据库链接一项配置的都是这个虚拟IP,当服务器发生故障无法对外提供服务时,动态将这个虚拟IP地址切换到备用主机。
在其中的一些实施例中,将主机IP地址虚拟成虚拟IP地址,并将虚拟IP地址挂载到正在运行的主机或虚拟机上包括:通过keepalive服务监听主机或虚拟机的是否正在运行;在监听主机正在运行的情况下,将虚拟IP地址挂载到主机上,或,在监听到虚拟机正在运行的情况下,将虚拟IP地址挂载到虚拟机上。
在本实施例中,配置keepalive服务时,在原主机和新的虚拟机中都进行keepalive服务的配置,配置命令可以通过web服务下发到原主机和新的虚拟机中,并由原主机和虚拟机分别完成keepalive服务配置,通过该方式,以实现虚拟IP地址的在主机和虚拟机之间的热切换。
keepalive,是在TCP中一个可以检测死连接的机制,VIP自动漂移到存活的主机(两台主机互为主备,或者双主机),保证服务高可用性。
在其中的一些实施例中,在通过keepalive服务将主机IP虚拟成虚拟IP地址之前,还可以在主机和虚拟机中配置keepalive服务。
在本实施例中,通过预先在主机和虚拟机中配置keepalive服务的方式,可以便于后续实现主机和虚拟机之间的热切换。
在本实施例中还提供了一种高可用部署架构示意图,如图3所示,该架构包括:主机和备份机(相当于上述实施例中的虚拟机中),其中,VIP挂载该主机和备份机之间,以实现热切换。主机和备份机都包括:Redis缓存、MySQL数据库、防护***(WAF)、堡垒机、防火墙(FW)、许可证明、天池、认证服务(cas)。
下面通过优选实施例对本实施例进行描述和说明。
图4是本优选实施例的高可用部署方法的流程图,可应用如图3中的高可用部署架构,如图4所示,该高可用部署方法包括如下步骤:
步骤S401,检验主机中的主机IP地址是否正确以及端口是否可以使用,若检验到主机中的主机IP地址正确以及端口可以使用,则执行步骤S402,若否,则结束。
步骤S402,开通防火墙。
步骤S403,检验主机中的MySQL数据库和Redis缓存是否能使用,若检验主机中的MySQL数据库和Redis缓存均能使用,执行步骤S404,若否,则结束。
步骤S404,通过数据库部署程序,在虚拟机中配置MySQL数据库的高可用部署。
步骤S405,通过缓存部署程序,在虚拟机中配置Redis缓存的高可用部署。
步骤S406,在主机和虚拟机中配置的keepalive服务。
步骤S407,将主机中的数据库信息同步到虚拟机中。
步骤S408,重启主机和虚拟机的应用。
在S408之后,还可以对虚拟机的各项服务进行检查,检测虚拟机的各项服务是否与主机的主机信息相同,若是,则结束,若否,则继续执行步骤S407。
通过上述步骤,实现了单体应用在主机和虚拟机之间的高可用性部署,避免相关技术中单体应用的部署依赖ansible(自动化运维工具)软件并需要准备相关配置脚本、操作复杂而且面向实施人员,并且仍需要在每台服务器上安装好业务***,而造成软件部署复杂的问题,简化了软件部署。
在本实施例中还提供了一种高可用性部署装置,该装置用于实现上述实施例及优选实施方式,已经进行过说明的不再赘述。以下所使用的术语“模块”、“单元”、“子单元”等可以实现预定功能的软件和/或硬件的组合。尽管在以下实施例中所描述的装置较佳地以软件来实现,但是硬件,或者软件和硬件的组合的实现也是可能并被构想的。
图5是本实施例的高可用性部署装置的结构框图,如图5所示,该装置包括:
第一获取模块51,用于获取虚拟机镜像文件,其中,虚拟机镜像文件用于创建虚拟机,虚拟机安装有预设单体应用、预设单体应用对应的中间件以及高可用性部署程序,其中,中间件包括以下至少之一:数据库功能模块、缓存功能模块;
创建模块52,耦合至第一获取模块51,用于基于虚拟机镜像文件,创建虚拟机,并在虚拟机启动时执行高可用性部署程序;
部署模块53,耦合至创建模块52,用于响应于数据库部署程序的执行,基于预设单体应用以及数据库功能模块进行预设单体应用中的SQL数据库高可用性部署。
在其中的一些实施例中,所述高可用性部署程序包括:数据库部署程序和缓存部署程序。
在其中的一些实施例中,部署模块53包括:第一配置单元,用于响应于数据库部署程序的执行,配置虚拟机中SQL数据库文件;第一获取单元,用于获取主机中SQL数据库文件的binlog文件名称和位置;第二配置单元,用于基于主机中SQL数据库文件的binlog文件名称和位置,配置主从同步服务;第一部署单元,用于执行主从同步服务,在虚拟机中进行SQL数据库的高可用性部署。
在其中的一些实施例中,部署模块53还包括:第三配置单元,用于响应于数据库部署程序的执行,配置虚拟机中SQL数据库文件;第二获取单元,用于获取主机中SQL数据库文件的binlog文件名称和位置;第四配置单元,用于基于主机中SQL数据库文件的binlog文件名称和位置,配置主从同步服务;第二部署单元,用于执行主从同步服务,在虚拟机中进行SQL数据库的高可用性部署。
在其中的一些实施例中,该装置还包括:检测模块,用于检测主机中的数据库的数据与虚拟机进行高可用性部署之后的数据库的数据是否相同;同步模块,用于在检测主机中的数据库的数据与虚拟机进行高可用性部署之后的数据库的数据不相同的情况下,响应于高可用性部署程序的执行,将主机中的数据库的数据同步到虚拟机中的数据库。
在其中的一些实施例中,该装置还包括:第二获取模块,用于获取主机的主机IP地址;挂载模块,用于将主机IP地址虚拟成虚拟IP地址,并将虚拟IP地址挂载到正在运行的主机或虚拟机上。
在其中的一些实施例中,挂载模块包括:虚拟单元,用于通过keepalive服务将主机IP虚拟成虚拟IP地址;监听单元,用于通过keepalive服务监听主机或虚拟机的是否正在运行;挂载单元,用于在监听主机正在运行的情况下,将虚拟IP地址挂载到主机上,或,在监听到虚拟机正在运行的情况下,将虚拟IP地址挂载到虚拟机上。
在其中的一些实施例中,该装置还包括:配置模块,用于在主机和虚拟机中配置keepalive服务。
需要说明的是,上述各个模块可以是功能模块也可以是程序模块,既可以通过软件来实现,也可以通过硬件来实现。对于通过硬件来实现的模块而言,上述各个模块可以位于同一处理器中;或者上述各个模块还可以按照任意组合的形式分别位于不同的处理器中。
在本实施例中还提供了一种电子装置,包括存储器和处理器,该存储器中存储有计算机程序,该处理器被设置为运行计算机程序以执行上述任一项方法实施例中的步骤。
可选地,上述电子装置还可以包括传输设备以及输入输出设备,其中,该传输设备和上述处理器连接,该输入输出设备和上述处理器连接。
可选地,在本实施例中,上述处理器可以被设置为通过计算机程序执行以下步骤:
步骤S201,获取虚拟机镜像文件,其中,虚拟机镜像文件用于创建虚拟机,虚拟机安装有预设单体应用、预设单体应用对应的中间件以及高可用性部署程序,其中,中间件包括以下至少之一:数据库功能模块、缓存功能模块。
步骤S202,基于虚拟机镜像文件,创建虚拟机,并在虚拟机启动时执行高可用性部署程序。
步骤S203,响应于高可用性部署程序的执行,基于预设单体应用以及中间件进行预设单体应用的高可用性部署。
需要说明的是,在本实施例中的具体示例可以参考上述实施例及可选实施方式中所描述的示例,在本实施例中不再赘述。
此外,结合上述实施例中提供的高可用性部署方法,在本实施例中还可以提供一种存储介质来实现。该存储介质上存储有计算机程序;该计算机程序被处理器执行时实现上述实施例中的任意一种高可用性部署方法。
应该明白的是,这里描述的具体实施例只是用来解释这个应用,而不是用来对它进行限定。根据本申请提供的实施例,本领域普通技术人员在不进行创造性劳动的情况下得到的所有其它实施例,均属本申请保护范围。
显然,附图只是本申请的一些例子或实施例,对本领域的普通技术人员来说,也可以根据这些附图将本申请适用于其他类似情况,但无需付出创造性劳动。另外,可以理解的是,尽管在此开发过程中所做的工作可能是复杂和漫长的,但是,对于本领域的普通技术人员来说,根据本申请披露的技术内容进行的某些设计、制造或生产等更改仅是常规的技术手段,不应被视为本申请公开的内容不足。
“实施例”一词在本申请中指的是结合实施例描述的具体特征、结构或特性可以包括在本申请的至少一个实施例中。该短语出现在说明书中的各个位置并不一定意味着相同的实施例,也不意味着与其它实施例相互排斥而具有独立性或可供选择。本领域的普通技术人员能够清楚或隐含地理解的是,本申请中描述的实施例在没有冲突的情况下,可以与其它实施例结合。
以上所述实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对专利保护范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请的保护范围应以所附权利要求为准。

Claims (10)

1.一种高可用性部署方法,其特征在于,包括:
获取虚拟机镜像文件,其中,所述虚拟机镜像文件用于创建虚拟机,所述虚拟机安装有预设单体应用、所述预设单体应用对应的中间件以及高可用性部署程序,其中,所述中间件包括以下至少之一:数据库功能模块、缓存功能模块;
基于所述虚拟机镜像文件,创建所述虚拟机,并在所述虚拟机启动时执行所述高可用性部署程序;
响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署。
2.根据权利要求1所述的高可用性部署方法,其特征在于,所述高可用性部署程序包括:数据库部署程序;响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署包括:
响应于所述数据库部署程序的执行,配置所述虚拟机中SQL数据库文件;
获取主机中SQL数据库文件的binlog文件名称和位置;
基于所述主机中SQL数据库文件的binlog文件名称和位置,配置主从同步服务;
执行所述主从同步服务,在所述虚拟机中进行SQL数据库的高可用性部署。
3.根据权利要求1所述的高可用性部署方法,其特征在于,所述高可用性部署程序包括:缓存部署程序;响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署包括:
响应于所述数据库部署程序的执行,配置所述虚拟机中Redis缓存文件;
获取主机中Redis缓存文件的binlog文件名称和位置;
基于所述主机中Redis缓存文件的binlog文件名称和位置,配置主从同步服务;
执行所述主从同步服务,在所述虚拟机中进行Redis缓存的高可用性部署。
4.根据权利要求1所述的高可用性部署方法,其特征在于,在响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署之后,所述方法还包括:
检测主机中的数据库的数据与所述虚拟机进行高可用性部署之后的数据库的数据是否相同;
在检测所述主机中的数据库的数据与所述虚拟机进行高可用性部署之后的数据库的数据不相同的情况下,响应于所述高可用性部署程序的执行,将所述主机中的数据库的数据同步到所述虚拟机中的数据库。
5.根据权利要求1所述的高可用性部署方法,其特征在于,在响应于所述高可用性部署程序的执行,基于所述预设单体应用以及所述中间件进行所述预设单体应用的高可用性部署之前,所述方法还包括:
获取主机的主机IP地址;
将所述主机IP地址虚拟成虚拟IP地址,并将所述虚拟IP地址挂载到正在运行的所述主机或虚拟机上。
6.根据权利要求5所述的高可用性部署方法,其特征在于,将所述主机IP地址虚拟成虚拟IP地址,并将所述虚拟IP地址挂载到正在运行的所述主机或虚拟机上包括:
通过keepalive服务监听所述主机或所述虚拟机的是否正在运行;
在监听所述主机正在运行的情况下,将所述虚拟IP地址挂载到所述主机上,或,在监听到所述虚拟机正在运行的情况下,将所述虚拟IP地址挂载到虚拟机上。
7.根据权利要求6所述的高可用性部署方法,其特征在于,在通过keepalive服务将所述主机IP虚拟成所述虚拟IP地址之前,所述方法还包括:
在所述主机和所述虚拟机中配置所述keepalive服务。
8.一种高可用性部署装置,其特征在于,包括:
第一获取模块,用于获取虚拟机镜像文件,其中,所述虚拟机镜像文件用于创建虚拟机,所述虚拟机安装有预设单体应用、所述预设单体应用对应的中间件以及高可用性部署程序,其中,所述中间件包括以下至少之一:数据库功能模块、缓存功能模块;
创建模块,用于基于所述虚拟机镜像文件,创建所述虚拟机,并在所述虚拟机启动时执行所述高可用性部署程序;
部署模块,用于响应于所述数据库部署程序的执行,基于所述预设单体应用以及所述数据库功能模块进行所述预设单体应用中的SQL数据库高可用性部署。
9.一种电子装置,包括存储器和处理器,其特征在于,所述存储器中存储有计算机程序,所述处理器被设置为运行所述计算机程序以执行权利要求1至7中任一项所述的高可用性部署方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现权利要求1至7中任一项所述的高可用性部署方法的步骤。
CN202110981539.XA 2021-08-25 2021-08-25 高可用性部署方法、装置、电子装置和存储介质 Withdrawn CN113741908A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110981539.XA CN113741908A (zh) 2021-08-25 2021-08-25 高可用性部署方法、装置、电子装置和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110981539.XA CN113741908A (zh) 2021-08-25 2021-08-25 高可用性部署方法、装置、电子装置和存储介质

Publications (1)

Publication Number Publication Date
CN113741908A true CN113741908A (zh) 2021-12-03

Family

ID=78732780

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110981539.XA Withdrawn CN113741908A (zh) 2021-08-25 2021-08-25 高可用性部署方法、装置、电子装置和存储介质

Country Status (1)

Country Link
CN (1) CN113741908A (zh)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105956207A (zh) * 2016-07-01 2016-09-21 杭州帕拉迪网络科技有限公司 一种基于binlog的可配置的mysql数据库实时同步方法
WO2017162173A1 (zh) * 2016-03-22 2017-09-28 中兴通讯股份有限公司 云服务器集群建立连接的方法和装置
US20170351535A1 (en) * 2016-06-06 2017-12-07 Vmware, Inc. Multitier application blueprint representation in open virtualization format package
CN111124595A (zh) * 2018-11-01 2020-05-08 阿里巴巴集团控股有限公司 一种提供云计算服务的方法及***
CN111158851A (zh) * 2019-12-10 2020-05-15 航天物联网技术有限公司 一种虚拟机快速部署方法

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2017162173A1 (zh) * 2016-03-22 2017-09-28 中兴通讯股份有限公司 云服务器集群建立连接的方法和装置
US20170351535A1 (en) * 2016-06-06 2017-12-07 Vmware, Inc. Multitier application blueprint representation in open virtualization format package
CN105956207A (zh) * 2016-07-01 2016-09-21 杭州帕拉迪网络科技有限公司 一种基于binlog的可配置的mysql数据库实时同步方法
CN111124595A (zh) * 2018-11-01 2020-05-08 阿里巴巴集团控股有限公司 一种提供云计算服务的方法及***
CN111158851A (zh) * 2019-12-10 2020-05-15 航天物联网技术有限公司 一种虚拟机快速部署方法

Similar Documents

Publication Publication Date Title
CN108551487B (zh) PaaS平台的应用部署方法、装置、服务器及存储介质
US10353728B2 (en) Method, system and device for managing virtual machine software in cloud environment
US9032248B1 (en) Memory write tracking for virtual machines
CN109067877B (zh) 一种云计算平台部署的控制方法、服务器及存储介质
CN103618627B (zh) 一种管理虚拟机的方法、装置及***
CN106919485B (zh) 一种基于服务器上配置硬件测试工具的***
WO2019146763A1 (ja) ロボットアプリケーション管理装置、システム、方法及びプログラム
CN111669284B (zh) OpenStack自动化部署方法、电子设备、存储介质及***
CN108667639B (zh) 一种私有云环境下的资源管理方法及管理服务器
JP2013218687A (ja) サーバー監視システム及びその方法
CN111131146A (zh) 一种广域环境下多超算中心软件***部署和增量更新方法
EP3332325A1 (en) Methods, apparatus, and systems for providing access to serial ports of virtual machines in self-deployed virtual applications
US20150242236A1 (en) Operation verification device for virtual apparatus, and operation verification system and program for virtual apparatus
CN106406933B (zh) 一种Tomcat集群一键自动部署方法
TWI648637B (zh) 於平台部署與操作行動作業系統的系統及其方法
CN114866515A (zh) Ip地址配置方法、装置、电子设备及存储介质
KR20150059173A (ko) 데이터 서버와 네트워크 소켓을 수립하는 방법
CN113886153B (zh) 一种基于容器的网卡压力测试方法及装置
CN109120680B (zh) 一种控制***、方法及相关设备
CN112948008A (zh) 一种基于Ironic管理物理裸机的方法
CN117453240A (zh) 一种裸金属服务器的raid配置方法、装置、设备及介质
CN113741908A (zh) 高可用性部署方法、装置、电子装置和存储介质
CN112099902A (zh) 虚拟机的网络适配器配置方法、装置、电子装置和存储介质
US9432476B1 (en) Proxy data storage system monitoring aggregator for a geographically-distributed environment
CN116048618A (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
WW01 Invention patent application withdrawn after publication
WW01 Invention patent application withdrawn after publication

Application publication date: 20211203