CN112114833A - 一种确定中间件安装部署的装置和方法 - Google Patents

一种确定中间件安装部署的装置和方法 Download PDF

Info

Publication number
CN112114833A
CN112114833A CN202010997110.5A CN202010997110A CN112114833A CN 112114833 A CN112114833 A CN 112114833A CN 202010997110 A CN202010997110 A CN 202010997110A CN 112114833 A CN112114833 A CN 112114833A
Authority
CN
China
Prior art keywords
middleware
available
available middleware
determining
deployment
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
CN202010997110.5A
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.)
China Construction Bank Corp
Original Assignee
China Construction Bank Corp
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 China Construction Bank Corp filed Critical China Construction Bank Corp
Priority to CN202010997110.5A priority Critical patent/CN112114833A/zh
Publication of CN112114833A publication Critical patent/CN112114833A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/71Version control; Configuration management

Landscapes

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

Abstract

本发明公开了一种确定中间件安装部署方案的装置和方法,涉及计算机技术领域。该装置的一具体实施方式包括:注册模块,用于注册至少一个可用中间件,并为至少一个可用中间件创建初始剧本;剧本管理模块,对于每一可用中间件,根据可用中间件的安装部署流程对可用中间件的初始剧本进行编排,得到可用中间件的最终剧本;标签确定模块,用于确定至少一个可用中间件的标签;方案生成模块,用于接收来自用户的应用目标信息,根据可用中间件的标签,确定与应用目标信息对应的至少一个目标中间件,并根据至少一个目标中间件的最终剧本,生成与应用目标信息对应的至少一个安装部署方案。该实施方式能够自动化、标准化部署中间件,提高部署效率。

Description

一种确定中间件安装部署的装置和方法
技术领域
本发明涉及计算机技术领域,尤其涉及一种确定中间件安装部署方案的装置和方法。
背景技术
随着计算机网络的不断发展,涌现出了各类底层中间件,主要有:采集管道、计算学习、存储、资源等几大领域。相同领域的中间件功能类似,但细节实现上各有所长,也存在诸多局限。不同领域的中间件虽然功能上不同,但可能作为上下游承接关系在实际落地场景中得到应用。中间件的选型以及部署策略直接影响着上层产品的性能表现。
目前,中间件的安装部署方式主要有以下几种:(1)人工直接操作计算机命令部署软件,即各个应用软件以及中间件的安装执行命令由运维人员手工编辑执行,该方法过程繁琐,且容易因为命令输入失误导致安装出错,效率很低;(2)人工执行预写好的安装脚本进行部署,该方法在一定程度上做到了集成,稍微简化了安装步骤,在一定程度上效率有所提高,但仍然不适合多中间件部署的场景;(3)将中间件以及部署相关命令合并,打包成一个大的可执行文件,该方法在大规模分部署场景中仍有局限。
发明内容
有鉴于此,本发明实施例提供一种确定中间件安装部署方案的装置和方法,该装置和方法能够自动化、标准化安装部署中间件,提高部署效率。
为实现上述目的,根据本发明实施例的一个方面,提供了一种确定中间件安装部署方案的装置,包括:
注册模块,用于注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;
剧本管理模块,用于对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;
标签确定模块,用于确定所述至少一个可用中间件的标签;
方案生成模块,用于接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案。
可选地,所述标签确定模块还用于:对所述至少一个可用中间件进行分类,并确定每一类可用中间件的标签;
所述方案生成模块还用于:基于所述至少一个可用中间件的分类,拆解所述应用目标信息,确定所述应用目标信息的至少一个特征;将所述至少一个特征与所述标签进行匹配,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件。
可选地,所述注册模块还用于:对于每一可用中间件,确定所述可用中间件的标识;将所述可用中间件的安装包上传至服务器,并记录所述安装包的版本号。
可选地,所述注册模块还用于:创建空剧本,将所述空剧本作为所述可用中间件的初始剧本,并在所述初始剧本中配置全局通用命令。
可选地,所述剧本管理模块还用于:对于每一可用中间件,在所述可用中间件的初始剧本中配置安装部署所述可用中间件所需的命令及参数,以得到所述可用中间件的最终剧本。
可选地,所述剧本管理模块还用于:在所述命令和参数配置完成后,根据所述命令和参数,模拟安装所述可用中间件,以校验所述命令和参数。
可选地,所述剧本管理模块还用于:若所述可用中间件模拟安装成功,则发起审核所述可用中间件的最终剧本的流程。
可选地,所述标签确定模块还用于:确定标签之间的关联关系,根据所述关联关系确定所述至少一个可用中间件之间的层级关系。
可选地,所述标签确定模块还用于:对于每一可用中间件,根据所述可用中间件的标签,生成所述可用中间件的多边形拓扑图,将所述多边形拓扑图作为所述可用中间件的画像。
可选地,所述标签确定模块还用于:确定所述可用中间件的标签的权重;
所述方案生成模块还用于:对于每一特征,将所述特征与所述标签进行匹配,确定与所述特征相匹配的可用中间件;当与所述特征相匹配的可用中间件有多个时,确定该多个可用中间件中所述标签的权重最大的可用中间件,将该标签的权重最大的可用中间件作为目标中间件。
可选地,所述方案生成模块还用于:响应于用户对所述安装部署方案中目标中间件的调整操作,更新所述安装部署方案。
可选地,所述方案生成模块还用于:确定与所述至少一个目标中间件对应的部署设备,关联所述至少一个目标中间件对应的部署设备,生成物理部署架构拓扑图;按照所述物理部署架构拓扑图,将所述至少一个目标中间件安装部署在所述部署设备上;当所述至少一个目标中间件安装部署成功之后,测试所述部署设备的性能。
为实现上述目的,根据本发明实施例的另一个方面,提供了一种确定中间件安装部署方案的方法,包括:
注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;
对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;
确定所述至少一个可用中间件的标签;
接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案。
可选地,确定所述至少一个可用中间件的标签包括:对所述至少一个可用中间件进行分类,并确定每一类可用中间件的标签;
根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件包括:基于所述至少一个可用中间件的分类,拆解所述应用目标信息,确定所述应用目标信息的至少一个特征;将所述至少一个特征与所述标签进行匹配,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件。
可选地,所述注册至少一个可用中间件包括:对于每一可用中间件,确定所述可用中间件的标识;将所述可用中间件的安装包上传至服务器,并记录所述安装包的版本号。
可选地,为所述至少一个可用中间创建初始剧本包括:创建空剧本,将所述空剧本作为所述至少一个可用中间件的初始剧本,并在所述初始剧本中配置全局通用命令。
可选地,根据所述至少一个可用中间件的安装部署流程对所述至少一个可用中间件的初始剧本进行编排,得到至少一个最终剧本包括:对于每一可用中间件,在所述可用中间件的初始剧本中配置安装部署所述可用中间件所需的命令及参数,以得到所述可用中间件的最终剧本。
可选地,所述方法在所述命令和参数配置完成后还包括:根据所述命令和参数,模拟安装所述可用中间件,以校验所述命令和参数。
可选地,所述方法还包括:若所述可用中间件模拟安装成功,则发起审核所述可用中间件的最终剧本的流程。
可选地,所述方法还包括:确定标签之间的关联关系,根据所述关联关系确定所述至少一个可用中间件之间的层级关系。
可选地,所述方法还包括:对于每一可用中间件,根据所述标签,生成所述可用中间件的多边形拓扑图,将所述多边形拓扑图作为所述可用中间件的画像。
可选地,所述方法还包括:确定所述可用中间件的标签的权重;
将所述至少一个特征与所述标签进行匹配,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件包括:对于每一特征,将所述特征与所述标签进行匹配,确定与所述特征相匹配的可用中间件;当与所述特征相匹配的可用中间件有多个时,确定该多个可用中间件中所述标签的权重最大的可用中间件,将该标签的权重最大的可用中间件作为目标中间件。
可选地,在生成与所述应用目标信息对应的至少一个安装部署方案之后,所述方法还包括:响应于用户对所述安装部署方案中目标中间件的调整操作,更新所述安装部署方案。
可选地,在生成与所述应用目标信息对应的至少一个安装部署方案之后,所述方法还包括:
确定与所述至少一个目标中间件对应的部署设备,关联所述至少一个目标中间件对应的部署设备,生成物理部署架构拓扑图;
按照所述物理部署架构拓扑图,将所述至少一个目标中间件安装部署在所述部署设备上;
当所述至少一个目标中间件安装部署成功之后,测试所述部署设备之间的性能。
为实现上述目的,根据本发明实施例的又一个方面,提供了一种电子设备,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明实施例的确定中间件安装部署方案的方法。
为实现上述目的,根据本发明实施例的一个方面,提供了一种计算机可读介质,其上存储有计算机程序,所述程序被处理器执行时实现本发明实施例的确定中间件安装部署方案的方法。
上述发明中的一个实施例具有如下优点或有益效果:通过注册模块注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;通过剧本管理模块对于每一可用中间件,根据所述至少一个可用中间件的安装部署流程对所述至少一个可用中间件的初始剧本进行编排,得到所述至少一个可用中间件的最终剧本得到所述可用中间件的最终剧本;通过标签确定模块确定所述至少一个可用中间件的标签;通过方案生成模块接收来自用户的应用目标信息,根据所述可用中间件的标签根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案的技术手段,所以能够自动化、标准化部署中间件,提高部署效率。
上述的非惯用的可用方式所具有的进一步效果将在下文中结合具体实施方式加以说明。
附图说明
附图用于更好地理解本发明,不构成对本发明的不当限定。其中:
图1是本发明实施例的确定中间件安装部署方案的装置的主要模块的示意图;
图2是应用本发明实施例的确定中间件安装部署方案的装置的系统架构图;
图3是本发明实施例的确定中间件安装部署方案的装置中的注册模块的功能示意图;
图4是本发明实施例的确定中间件安装部署方案的装置中的剧本管理模块的功能示意图;
图5是本发明实施例的确定中间件安装部署方案的装置中的标签确定模块的功能示意图;
图6是本发明实施例的确定中间件安装部署方案的装置中的方案生成模块的功能示意图;
图7是本发明实施例的确定中间件安装部署方案的方法的主要流程的示意图;
图8是本发明实施例可以应用于其中的示例性系统架构图;
图9是适于用来实现本发明实施例的终端设备或服务器的计算机系统的结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
图1是本发明实施例的确定中间件安装部署方案的装置100的主要模块的示意图,如图1所示,该确定中间件安装部署方案的装置100包括注册模块101、剧本管理模块102、标签确定模块103和方案生成模块104。
其中,注册模块101,用于注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;
剧本管理模块102,用于对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;
标签确定模块103,用于确定所述至少一个可用中间件的标签;
方案生成模块104,用于接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案。
本发明实施例的确定中间件安装部署方案的装置100通过以上注册模块101、剧本管理模块102、标签确定模块103和方案生成模块104,能够自动确定与用户的应用目标信息匹配的目标中间件,并获得该目标中间件的安装部署方案,根据该安装部署方案能够自动化、标转化安装部署目标中间件,提高部署效率。
其中,注册模块101用于对于每一可用中间件,确定所述可用中间件的标识;将所述可用中间件的安装包上传至服务器,并记录所述安装包的版本号。作为示例,在注册可用中间件的时候为该可用中间件进行命名,将该命名作为该可用中间件的标识,并将该可用中间件的安装包上传至服务器中,作为后续该可用中间件安装部署的可安装软件。其中,同一可用中间件可以同时注册多个版本的安装包,不同版本的安装包需要单独维护,在后续方案部署中根据实际提供的环境选择合适的版本进行安装。在可选的实施例中,可以将可用中间件的标识存储到数据库中,以便于后续查询。
在可选的实施例中,注册模块101为可用中间件创建初始剧本包括:创建空剧本,将所述空剧本作为所述可用中间件的初始剧本,并在所述初始剧本中配置全局通用命令。其中,剧本可以被描述为一个需要希望远程主机执行命令的方案,或者一组程序运行的命令集合。全局通用命令是指该命令在程序中任何位置都可以访问到。在本实施例中,任何一次注册可用中间件(包括加入新版本)都需要为该可用中间件生成初始剧本。对于相同可用中间件不同版本的情况下,也可以选择继承旧版本的最终剧本。
在可选的实施例中,注册模块101还用于修改、查询或者删除可用中间件。
剧本管理模块102主要用于根据可用中间件安装部署流程对初始剧本进行编排。其中,剧本编排是指在初始剧本中配置安装部署该可用中间件所需的命令及参数,以得到该可用中间件的最终剧本。作为示例,对初始剧本进行编排的风格可以参考Ansible的playbook(剧本)。Ansible是一种自动化运维部署的架构。
在可选的实施例中,剧本管理模块102还用于在所述命令和参数配置完成后,根据所述命令和参数,模拟安装所述可用中间件,以校验所述命令和参数。具体的,在得到最终剧本后,可在测试环境中安排最终剧本演练,主要是按照最终剧本的流程执行安装部署操作,验证最终剧本的正确性,即校验上述命令和参数的正确性。若最终剧本模拟安装失败,则退回该最终剧本,以对该最终剧本进行修改。
在可选的实施例中,剧本管理模块102还用于:若所述可用中间件模拟安装成功,则发起审核所述可用中间件的最终剧本的流程。作为示例,审核该最终剧本可以审核该最终剧本中的参数的合理性和该最终剧本是否符合预设的安全规范。
在可选的实施例中,剧本管理模块102还用于:若所述可用中间件的最终剧本审核通过,则发布所述最终剧本;若所述可用中间件的最终剧本审核不通过,则可以回退所述最终剧本。
在本实施例中,剧本管理模块统一管理可用中间件的最终剧本,避免安装差异带来的环境差异。
标签确定模块103从中间件中提炼出适配性因素,如所属类型、处理性能、消息接收模式等,形成中间件的画像昂,并进行画像管理。标签确定模块103以标签作为基本元素,刻画每个可用中间件的画像。每个可用中间件可以创建多类标签。具体的,该标签确定模块103用于:对所述至少一个可用中间件进行分类,并确定每一类可用中间件的标签。在可选的实施例中,根据日常架构选型的思维对可用中间件进行分类,并确定每一类可用中间件的标签。例如可以将可用中间件分为:采集、计算、存储、资源、调度、查询分析等。每个分类按照关联关系确定不同层级,例如:存储类向下可连接采集和计算,向上可连接计算和查询分析等。优选的,还可以在每个分类内部细分,例如按照非功能特性分为:高可用、处理性能、可扩展性、易用性等;按照接收消息渠道分为:HTTP(Hyper Text Transfer Protocol,超文本传输协议)、JDBC(Java Database Connectivity,数据库连接池)、FTP(FileTransfer Protocol,文件传输协议)等。经过多个不同维度的标签确定可用中间件的画像。标签越细,画像越明确。
作为示例,以大数据架构为例,在大数据解决方案中,中间件可以分为采集、消息队列、存储、计算、查询、监控和调度等几大类。在这几类中还可以对中间件进行细分,例如计算还可以分为实时计算和离线计算。离线计算的中间件包括:Spark batch(Spark是专为大规模数据处理而设计的快速通用的计算引擎,batch是指批处理脚本)、Flink batch(Flink是由Apache软件基金会开发的开源流处理框架,其核心是用Java和Scala编写的分布式流数据流引擎)、MapReduce(MapReduce是一种编程模型,用于大规模数据集的并行运算)等;实时计算架构有:Spark Stream(Spark Stream是一个准流式计算框架)、FlinkStream、Storm(Storm是一个流式计算框架)等。因此,可以将采集、消息队列、存储、计算、实时计算、离线计算、查询、监控和调度作为中间件的标签。确定上述标签后,还可以根据中间件的非功能性特点再次细分,例如按照性能、成熟度、部署复杂度和热度等进行细分。进而,可以将上述中间件按照如下方式划分:
一级分类:计算;
二级分类:实时计算;
三级分类:性能:Flink Stream>Spark Stream>Storm;
三级分类:成熟度:Spark Stream>Flink Stream>Storm;
三级分类:部署复杂度:Spark Stream=Flink Stream=Storm;
三级分类:热度:Flink Stream>Spark Stream>Storm;
二级分类:离线计算;
三级分类:性能:Spark Batch=Flink Batch>MapReduce;
三级分类:成熟度:Spark Batch=MapReduce>Flink Batch;
三级分类:部署复杂度:MapReduce>Spark Batch=Flink Batch。
其中,Flink Stream>Spark Stream>Storm是指Flink Stream的性能优于SparkStream,Spark Stream的性能优于Storm。在本实施例,为可用中间件的标签设置了权重,因此,Flink Stream的性能标签的权重大于Spark Stream性能标签的权重,Spark Stream性能标签的权重大于Storm性能标签的权重。Spark Stream=Flink Stream=Storm是指Spark Stream、Flink Stream、Storm的部署复杂度相同,三者的部署复杂度标签的权重相同。
由上可知,中间件的特性是可标签化的,因此,可以确定每一个中间件的画像,进而可以在具体使用场景中根据实际需求以及条件约束确定安装部署方案。
可选地,所述标签确定模块103还用于:确定标签之间的关联关系。通过标签之间的关联关系实现安装部署方案最优。例如,可以根据可用中间件的非功能性标签与上下级可用中间件进行标签关联。例如,计算中间件的高实时性与存储的高吞吐关联。
在可选的实施例中,标签确定模块103还用于:对于每一可用中间件,根据所述标签,生成所述可用中间件的多边形拓扑图,将所述多边形拓扑图作为所述可用中间件的画像。在本实施例中,通过可用中间件的多边形拓扑图,能够直观的看出个可用中间件的优势和劣势,进而可以确定该可用中间件的适用场景,从而为确定安装部署方案提供基础数据支撑。
在可选的实施例中,标签确定模块103还用于确定可用中间件的标签的权重。在本实施例中,设置权重的目的是用于描述中间件与标签的匹配度。因此,权重的值可以根据可用中间件自身的特性设置。在本实施例中,若方案生成模块104确定的目标中间件有多个,则可以选择标签权重最高的目标中间件作为最优目标中间件。
在可选的实施例中,标签确定模块103还可以用于修改所述可用中间件的标签及删除该可用中间件的标签。
方案生成模块104用于确定与应用目标信息对应的中间件安装部署方案。该方案生成模块104通过对项目需求人员提出的应用目标信息进行特征分析,并按照可用中间件定义的标签维度进行拆解,再对拆解的特征因素与可用中间件的标签逐一适配,找出最合适的可用中间件架构方案。当不同类型的可用中间件较多的时候,一般会给出多个安装部署方案,以及每个安装部署方案的优劣势等,需求人员根据实际情况选择最符合应用场景的安装部署方案即可。方案生成模块以可用中间件的标签/画像为基础,为上层实际应用场景提供统一的解决方案,形成解决方案库。不仅完成了中间件如何利用剧本快速部署,还做到了上层需求到中间件选型的自动转换。真正实现了需求方案从提出到落地的快速组装集成。
方案生成模块104还用于:响应于用户对所述安装部署方案中目标中间件的调整操作,更新所述安装部署方案。
在可选的实施例中,该方案生成模块104还用于:
确定与所述至少一个目标中间件对应的部署设备,关联所述至少一个目标中间件对应的部署设备,生成物理部署架构拓扑图;
按照所述物理部署架构拓扑图,将所述至少一个目标中间件安装部署在所述部署设备上;
当所述至少一个目标中间件安装部署成功之后,测试所述部署设备的性能。
其中,拓扑图是指由网络节点设备(即本实施例中目标中间件对应的部署设备)和通信介质构成的网络结构图。在目标中间件安装部署成功之后,可对安装部署方案的每个环节进行验证测试,可以包括连通性测试以及高可用测试。
本发明实施例的确定中间件安装部署方案的装置,通过注册模块注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;通过剧本管理模块对于每一可用中间件,根据所述至少一个可用中间件的安装部署流程对所述至少一个可用中间件的初始剧本进行编排,得到所述至少一个可用中间件的最终剧本得到所述可用中间件的最终剧本;通过标签确定模块确定所述至少一个可用中间件的标签;通过方案生成模块接收来自用户的应用目标信息,根据所述可用中间件的标签根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案的技术手段,所以能够自动化、标准化部署中间件,提高部署效率。
在可选的实施例中,该确定中间件安装部署方案的装置包括用户管理模块、系统管理模块、权限管理模块、服务器管理模块以及信息收集等模块。其中,用户管理模块用于管理用户信息。系统管理模块用于管理确定中间件安装部署方案的装置,权限管理模块用于管理用户的权限,服务器管理模块用于管理相关服务器/部署设备,信息收集模块用于收集相关服务器/部署设备的信息及目标应用信息对应的安装部署方案。
图2是应用本发明实施例的确定中间件安装部署方案的装置的系统架构图,如图2所示,该系统的底层是Ansible架构,在Ansible架构上设置了注册模块、剧本管理模块、标签确定模块和方案生成模块,在注册模块、剧本管理模块、标签确定模块和方案生成模块之上设置了可视化页面。其中,Ansible是一种自动化运维部署的架构。图3所示,注册模块主要实现可用中间件的注册和维护功能,包括可用中间件的注册、命名、软件包(即安装包)上传、版本管理以及修改、查看、删除可用中间件的信息等功能。如图4所示,剧本管理模块用于对初始剧本进行编排得到最终剧本,然后模拟安装最终剧本并审核该最终剧本。对初始剧本进行编排是指是指在初始剧本中配置安装部署该可用中间件所需的命令及参数,以得到该可用中间件的最终剧本。如图4所示,标签确定模块用于创建、识别、关联、修改、注销标签,并根据标签生成画像。如图5所示,方案生成模块用于根据用户的应用目标信息,从可用中间件中确定与应用目标信息对应的目标中间件,并根据目标中间件的最终剧本,生成与该应用目标信息对应的安装部署方案,然后响应于用户对安装部署方案的修改操作,更新该安装部署方案。让后发布执行该安装部署方案并验证该安装部署方案。可视化页面主要为用户提供统一的访问管理入口,如注册模块、剧本管理模块、标签确定模块和方案生成模块等。
图6是本发明实施例的确定中间件安装部署方案的方法主要步骤的流程图,如图6所示,该方法包括:
步骤S601:注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;
步骤S602:对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;
步骤S603:确定所述至少一个可用中间件的标签;
步骤S604:接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案。
本发明实施例的确定中间件安装部署方案的方法,通过注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;确定所述至少一个可用中间件的标签;接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案,实现了自动化、标准化部署中间件,提高了部署效率。
可选地,确定所述至少一个可用中间件的标签包括:对所述至少一个可用中间件进行分类,并确定每一类可用中间件的标签;
根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件包括:基于所述至少一个可用中间件的分类,拆解所述应用目标信息,确定所述应用目标信息的至少一个特征;将所述至少一个特征与所述标签进行匹配,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件。
可选地,所述注册至少一个可用中间件包括:对于每一可用中间件,确定所述可用中间件的标识;将所述可用中间件的安装包上传至服务器,并记录所述安装包的版本号。
可选地,为所述至少一个可用中间创建初始剧本包括:创建空剧本,将所述空剧本作为所述至少一个可用中间件的初始剧本,并在所述初始剧本中配置全局通用命令。
可选地,根据所述至少一个可用中间件的安装部署流程对所述至少一个可用中间件的初始剧本进行编排,得到至少一个最终剧本包括:对于每一可用中间件,在所述可用中间件的初始剧本中配置安装部署所述可用中间件所需的命令及参数,以得到所述可用中间件的最终剧本。
可选地,所述方法在所述命令和参数配置完成后还包括:根据所述命令和参数,模拟安装所述可用中间件,以校验所述命令和参数。
可选地,所述方法还包括:若所述可用中间件模拟安装成功,则发起审核所述可用中间件的最终剧本的流程。
可选地,所述方法还包括:确定标签之间的关联关系,根据所述关联关系确定所述至少一个可用中间件之间的层级关系。
可选地,所述方法还包括:对于每一可用中间件,根据所述标签,生成所述可用中间件的多边形拓扑图,将所述多边形拓扑图作为所述可用中间件的画像。
可选地,所述方法还包括:确定所述可用中间件的标签的权重;
将所述至少一个特征与所述标签进行匹配,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件包括:对于每一特征,将所述特征与所述至少一个可用中间件的标签进行匹配,确定与所述特征相匹配的可用中间件,将与所述特征相匹配的可用中间件作为可选中间件;
当所述可选中间件有多个时,从多个可选中间件中确定标签权重最大的可选中间件,将所述标签权重最大的可选中间件作为目标中间件。
可选地,在生成与所述应用目标信息对应的至少一个安装部署方案之后,所述方法还包括:响应于用户对所述安装部署方案中目标中间件的调整操作,更新所述安装部署方案。
可选地,在生成与所述应用目标信息对应的至少一个安装部署方案之后,所述方法还包括:
确定与所述至少一个目标中间件对应的部署设备,关联所述至少一个目标中间件对应的部署设备,生成物理部署架构拓扑图;
按照所述物理部署架构拓扑图,将所述至少一个目标中间件安装部署在所述部署设备上;
当所述至少一个目标中间件安装部署成功之后,测试所述部署设备之间的性能。
在可选的实施例中,该中间件安装部署装置提供可视化操作页面,该可视化操作页面主要为用户提供统一的访问管理入口,主要包含:中间件注册管理、剧本管理、中间件画像管理,以及其他辅助模块,如:用户管理、系统管理、角色管理、服务器管理等。
图7示出了可以应用本发明实施例的确定中间件安装部署方案的方法或确定中间件安装部署方案的装置的示例性系统架构700。
如图7所示,系统架构700可以包括终端设备701、702、703,网络704和服务器705。网络704用以在终端设备701、702、703和服务器705之间提供通信链路的介质。网络704可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备701、702、703通过网络704与服务器705交互,以接收或发送消息等。终端设备701、702、703上可以安装有各种通讯客户端应用。
终端设备701、702、703可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器705可以是提供各种服务的服务器,服务器可以对接收到的目标应用信息等数据进行分析等处理,并将处理结果(例如安装部署方案)反馈给终端设备。
需要说明的是,本发明实施例所提供的确定中间件安装部署方案的方法一般由服务器705执行,相应地,确定中间件安装部署方案的装置一般设置于服务器705中。
应该理解,图7中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
下面参考图8,其示出了适于用来实现本发明实施例的服务器设备的计算机系统800的结构示意图。图8示出的终端设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图8所示,计算机系统800包括中央处理单元(CPU)801,其可以根据存储在只读存储器(ROM)802中的程序或者从存储部分808加载到随机访问存储器(RAM)803中的程序而执行各种适当的动作和处理。在RAM 803中,还存储有系统800操作所需的各种程序和数据。CPU 801、ROM 802以及RAM 803通过总线804彼此相连。输入/输出(I/O)接口805也连接至总线804。
以下部件连接至I/O接口805:包括键盘、鼠标等的输入部分806;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分807;包括硬盘等的存储部分808;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分809。通信部分809经由诸如因特网的网络执行通信处理。驱动器810也根据需要连接至I/O接口805。可拆卸介质811,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器810上,以便于从其上读出的计算机程序根据需要被安装入存储部分808。
特别地,根据本发明公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分809从网络上被下载和安装,和/或从可拆卸介质811被安装。在该计算机程序被中央处理单元(CPU)801执行时,执行本发明的系统中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的模块可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的模块也可以设置在处理器中,例如,可以描述为:一种处理器包括发送模块、获取模块、确定模块和第一处理模块。其中,这些模块的名称在某种情况下并不构成对该单元本身的限定,例如,发送模块还可以被描述为“向所连接的服务端发送图片获取请求的模块”。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该设备执行时,使得该设备包括:
注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;
对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;
确定所述至少一个可用中间件的标签;
接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案。
本发明实施例的技术方案,能够自动化、标准化安装部署中间件,提高部署效率。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。

Claims (16)

1.一种确定中间件安装部署方案的装置,其特征在于,包括:
注册模块,用于注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;
剧本管理模块,用于对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;
标签确定模块,用于确定所述至少一个可用中间件的标签;
方案生成模块,用于接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案。
2.根据权利要求1所述的装置,其特征在于,所述标签确定模块还用于:对所述至少一个可用中间件进行分类,并确定每一类可用中间件的标签;
所述方案生成模块还用于:基于所述至少一个可用中间件的分类,拆解所述应用目标信息,确定所述应用目标信息的至少一个特征;将所述至少一个特征与所述标签进行匹配,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件。
3.根据权利要求1所述的装置,其特征在于,所述注册模块还用于:
对于每一可用中间件,确定所述可用中间件的标识;
将所述可用中间件的安装包上传至服务器,并记录所述安装包的版本号。
4.根据权利要求3所述的装置,其特征在于,所述注册模块还用于:创建空剧本,将所述空剧本作为所述可用中间件的初始剧本,并在所述初始剧本中配置全局通用命令。
5.根据权利要求1所述的装置,其特征在于,所述剧本管理模块还用于:对于每一可用中间件,在所述可用中间件的初始剧本中配置安装部署所述可用中间件所需的命令及参数,以得到所述可用中间件的最终剧本。
6.根据权利要求5所述的装置,其特征在于,所述剧本管理模块还用于:在所述命令和参数配置完成后,根据所述命令和参数,模拟安装所述可用中间件,以校验所述命令和参数。
7.根据权利要求6所述的装置,其特征在于,所述剧本管理模块还用于:若所述可用中间件模拟安装成功,则发起审核所述可用中间件的最终剧本的流程。
8.根据权利要求2所述的装置,其特征在于,所述标签确定模块还用于:确定标签之间的关联关系,根据所述关联关系确定所述至少一个可用中间件之间的层级关系。
9.根据权利要求8所述的装置,其特征在于,所述标签确定模块还用于:对于每一可用中间件,根据所述可用中间件的标签,生成所述可用中间件的多边形拓扑图,将所述多边形拓扑图作为所述可用中间件的画像。
10.根据权利要求9所述的装置,其特征在于,所述标签确定模块还用于:确定所述可用中间件的标签的权重;
所述方案生成模块还用于:对于每一特征,将所述特征与所述标签进行匹配,确定与所述特征相匹配的可用中间件;
当与所述特征相匹配的可用中间件有多个时,确定该多个可用中间件中所述标签的权重最大的可用中间件,将该标签的权重最大的可用中间件作为目标中间件。
11.根据权利要求1所述的装置,其特征在于,所述方案生成模块还用于:响应于用户对所述安装部署方案中目标中间件的调整操作,更新所述安装部署方案。
12.根据权利要求11所述的装置,其特征在于,所述方案生成模块还用于:
确定与所述至少一个目标中间件对应的部署设备,关联所述至少一个目标中间件对应的部署设备,生成物理部署架构拓扑图;
按照所述物理部署架构拓扑图,将所述至少一个目标中间件安装部署在所述部署设备上;
当所述至少一个目标中间件安装部署成功之后,测试所述部署设备的性能。
13.一种确定中间件安装部署方案的方法,其特征在于,包括:
注册至少一个可用中间件,并为所述至少一个可用中间件创建初始剧本;
对于每一可用中间件,根据所述可用中间件的安装部署流程对所述可用中间件的初始剧本进行编排,得到所述可用中间件的最终剧本;
确定所述至少一个可用中间件的标签;
接收来自用户的应用目标信息,根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件,并根据所述至少一个目标中间件的最终剧本,生成与所述应用目标信息对应的至少一个安装部署方案。
14.根据权利要求13所述的方法,其特征在于,确定所述至少一个可用中间件的标签包括:对所述至少一个可用中间件进行分类,并确定每一类可用中间件的标签;
根据所述标签,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件包括:基于所述至少一个可用中间件的分类,拆解所述应用目标信息,确定所述应用目标信息的至少一个特征;将所述至少一个特征与所述标签进行匹配,从所述至少一个可用中间件中确定与所述应用目标信息对应的至少一个目标中间件。
15.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求13-14中任一所述的方法。
16.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求13-14中任一所述的方法。
CN202010997110.5A 2020-09-21 2020-09-21 一种确定中间件安装部署的装置和方法 Pending CN112114833A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010997110.5A CN112114833A (zh) 2020-09-21 2020-09-21 一种确定中间件安装部署的装置和方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010997110.5A CN112114833A (zh) 2020-09-21 2020-09-21 一种确定中间件安装部署的装置和方法

Publications (1)

Publication Number Publication Date
CN112114833A true CN112114833A (zh) 2020-12-22

Family

ID=73801347

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010997110.5A Pending CN112114833A (zh) 2020-09-21 2020-09-21 一种确定中间件安装部署的装置和方法

Country Status (1)

Country Link
CN (1) CN112114833A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113220285A (zh) * 2021-04-22 2021-08-06 上海雾帜智能科技有限公司 安全事件响应剧本生成方法、系统、装置和存储介质

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120324069A1 (en) * 2011-06-17 2012-12-20 Microsoft Corporation Middleware Services Framework for On-Premises and Cloud Deployment
CN107885539A (zh) * 2016-09-28 2018-04-06 平安科技(深圳)有限公司 一种中间件管理方法及服务器
CN108845808A (zh) * 2018-06-22 2018-11-20 平安科技(深圳)有限公司 中间件安装方法、装置、计算机设备及存储介质
CN109614110A (zh) * 2018-11-19 2019-04-12 中国银行股份有限公司 一种消息中间件集中部署的方法和装置
CN110855746A (zh) * 2019-10-12 2020-02-28 重庆金融资产交易所有限责任公司 中间件管理方法、电子装置及存储介质
CN111045695A (zh) * 2019-12-15 2020-04-21 北京浪潮数据技术有限公司 WebLogic中间件部署装置、方法及设备和介质

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120324069A1 (en) * 2011-06-17 2012-12-20 Microsoft Corporation Middleware Services Framework for On-Premises and Cloud Deployment
CN107885539A (zh) * 2016-09-28 2018-04-06 平安科技(深圳)有限公司 一种中间件管理方法及服务器
CN108845808A (zh) * 2018-06-22 2018-11-20 平安科技(深圳)有限公司 中间件安装方法、装置、计算机设备及存储介质
CN109614110A (zh) * 2018-11-19 2019-04-12 中国银行股份有限公司 一种消息中间件集中部署的方法和装置
CN110855746A (zh) * 2019-10-12 2020-02-28 重庆金融资产交易所有限责任公司 中间件管理方法、电子装置及存储介质
CN111045695A (zh) * 2019-12-15 2020-04-21 北京浪潮数据技术有限公司 WebLogic中间件部署装置、方法及设备和介质

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113220285A (zh) * 2021-04-22 2021-08-06 上海雾帜智能科技有限公司 安全事件响应剧本生成方法、系统、装置和存储介质
CN113220285B (zh) * 2021-04-22 2023-08-22 上海雾帜智能科技有限公司 安全事件响应剧本生成方法、系统、装置和存储介质

Similar Documents

Publication Publication Date Title
US20210326128A1 (en) Edge Computing Platform
US10007513B2 (en) Edge intelligence platform, and internet of things sensor streams system
CN107370786B (zh) 一种基于微服务架构的通用信息管理系统
US8478623B2 (en) Automated derivation, design and execution of industry-specific information environment
US20200142679A1 (en) Constructing and enhancing a deployment pattern
CN111159897B (zh) 基于系统建模应用的目标优化方法和装置
CN111383100A (zh) 基于风险模型的全生命周期管控方法和装置
US20210216860A1 (en) Neural-network-based methods and systems that generate forecasts from time-series data
CN112114833A (zh) 一种确定中间件安装部署的装置和方法
US9117177B1 (en) Generating module stubs
US20220179380A1 (en) Service operation method for energy management for each tenant in multi-tenant environment, and energy management service supply system
Hass et al. Workload deployment and configuration reconciliation at scale in kubernetes-based edge-cloud continuums
CN114500268B (zh) chart资源的部署方法、装置、服务器及存储介质
SANTOSO et al. Improvement of setup time on server infrastructure automation using ansible framework
WO2023035147A1 (en) Data processing method of industry edge product and distributed computing protocol engine thereof
US20230385181A1 (en) Re-usable web-objects for use with automation tools
US20230056637A1 (en) Hardware and software configuration management and deployment
Barriga et al. Simulate IoT Towards the Cloud-to-Thing Continuum Paradigm for Task Scheduling Assessments.
CN116032745A (zh) hadoop集群的自动配置方法及装置
CN117675838A (zh) 一种智能量测主站数据自动同步及共享方法及系统
CN117608564A (zh) 一种服务开发方法、装置、设备及可读存储介质
CN113778476A (zh) 更新移动应用版本的方法、装置、设备和计算机可读介质
Svensson Automatic Log Analysis System Integration: Message Bus Integration in a Machine Learning Environment
CN117743128A (zh) 测试用例的建设方法、存储介质及电子设备
CN116594674A (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