中间件自动扫描装配方法、装置及存储介质与流程

文档序号:16067202发布日期:2018-11-24 12:47阅读:266来源:国知局

本发明涉及网络应用技术领域,尤其涉及一种中间件自动扫描装配方法、电子装置及计算机可读存储介质。

背景技术

spring框架目前是业务开发团队使用最广泛的开发框架。spring官方提供了针对日常企业应用研发各种场景的spring-boot-starter自动配置依赖模块。然而,每个项目会用到很多通用的中间件,比如:dubbo、rocketmq、tair等等。每个项目中都会有对这些中间件的重复配置代码和工具类,而且每个开发人员对于中间件的理解不同,使用方式代码风格也各不相同,对中间件可能存在误用、错用、滥用的情况,因此需要统一代码规范,减低代码维护成本、减少配置工作,减少代码量,缩短开发周期。



技术实现要素:

鉴于以上内容,本发明提供一种中间件自动扫描装配方法、服务器及计算机可读存储介质,其主要目的在于提高业务开发效率。

为实现上述目的,本发明提供一种中间件自动扫描装配方法,该方法包括:

s1、接收业务代码依赖的框架调用组件自动初始化程序的启动命令,从第一路径中获取预设的配置文件,其中,配置文件中包括:所述业务代码中涉及到的各中间件及所述各中间件必要的配置信息;

s2、读取所述配置文件中的第一配置信息,根据所述第一配置信息,从所述业务代码中扫描出待执行对象;及

s3、从第二路径中获取项目对象模型文件,读取所述配置文件中的第二配置信息,根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作,并进行组件增强及注入。

优选地,所述步骤s2包括:

s21、根据所述配置文件中的第一配置信息,确定所述业务代码中待扫描的类加载路径;

s22、根据所述类加载路径,扫描该类加载路径对应的每个类文件,判断所述类文件中是否包含添加注解的类;及

s23、当所述类文件中包含添加注解的类时,将所述添加注解的类作为待执行对象。

优选地,所述步骤s3中的“根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作”包括:

s31、根据所述项目对象模型文件中的坐标信息,从预设仓库中获取所述待执行对象对应的组件自动初始化程序的依赖;

s32、根据所述待执行对象对应的组件自动初始化程序的依赖,确定所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合;及

s33、根据所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合及所述第二配置信息,执行组件装配操作。

优选地,所述框架为springboot框架。

优选地,所述项目对象模型文件用于定义中间件与第三方组件、中间件与中间件的依赖关系。

此外,本发明还提供一种电子装置,其特征在于,该装置包括:存储器、处理器,所述存储器上存储有可在所述处理器上运行的中间件自动扫描装配程序,所述中间件自动扫描装配程序被所述处理器执行时,可实现如下步骤:

a1、接收业务代码依赖的框架调用组件自动初始化程序的启动命令,从第一路径中获取预设的配置文件,其中,配置文件中包括:所述业务代码中涉及到的各中间件及所述各中间件必要的配置信息;

a2、读取所述配置文件中的第一配置信息,根据所述第一配置信息,从所述业务代码中扫描出待执行对象;及

a3、从第二路径中获取项目对象模型文件,读取所述配置文件中的第二配置信息,根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作,并进行组件增强及注入。

此外,为实现上述目的,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质中包括中间件自动扫描装配程序,所述中间件自动扫描装配程序被处理器执行时,可实现如上所述中间件自动扫描装配方法中的任意步骤。

本发明提出的中间件自动扫描装配方法、电子装置及计算机可读存储介质,通过提供标准pom文件规范中间件与第三方组件、中间件与中间件之间的依赖关系,最大程度上降低jar包冲突的风险;预先定义各种注解来对业务代码进行标注,通过组件扫描器来完成功能的增强和注入;业务代码中不需要增加组件starter的接口,只需增加指定组件的注解即可使用,通过注解来实现功能的“内聚”;通过解决组件依赖和自动装配问题达到了简化项目配置,减少了使用代码量,提高开发效率。

附图说明

图1为本发明中间件自动扫描装配方法较佳实施例的流程图;

图2为本发明电子装置较佳实施例的示意图;

图3为图2中中间件自动扫描装配程序的程序模块示意图。

本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。

具体实施方式

应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。

本发明提供一种中间件自动扫描装配方法。参照图1所示,为本发明中间件自动扫描装配方法较佳实施例的流程图。该方法可以由一个装置执行,该装置可以由软件和/或硬件实现。

在本实施例中,中间件自动扫描装配方法包括步骤s1-s3:

s1、接收业务代码依赖的框架调用组件自动初始化程序的命令,从第一路径中获取预设的配置文件,其中,配置文件中包括:所述业务代码中涉及到的各中间件及所述各中间件必要的配置信息;

在本实施例中,以中间件rocketmq为例,但不仅限于中间件rocketmq,对本发明方案进行说明。

所述框架为springboot框架,业务开发人员基于springboot框架写入业务代码。所述组件自动初始化程序是将某些组件初始化操作自动化进行的程序,以下简称组件starter。

在启动springboot框架调用组件starter之前,需预先配置业务相关中间件的配置项,生成配置文件,并将配置文件保存至预设的第一路径中。其中,所述配置文件为yml文件,yml文件格式是yaml(yamlaintmarkuplanguage)编写的文件格式,yaml是一种直观的能够被电脑识别的的数据数据序列化格式,并且容易被人类阅读,容易和脚本语言交互的,可以被支持yaml库的不同的编程语言程序导入。

业务开发人员在写入业务代码时,可明确业务代码中涉及的中间件,例如,当业务代码中涉及中间件rocketmq时,需预先在配置文件中根据rocketmq-starter的要求对中间件rocketmq的配置项进行设置。

例如,针对中间件rocketmq在配置文件中预先设置的配置项包括:

rocketmq.group.name,表示消费者的组名;

rocketmq.consumer.minthread,表示消费者的最小线程数;

rocketmq.consumer.maxthread,表示消费者的最大线程数;

rocketmq.consumer.basepackage,表示需要被增强为消费者方法的包路径名;

rocketmq.domain.name,表示消费服务器的地址。

s2、读取所述配置文件中的第一配置信息,根据所述第一配置信息,从所述业务代码中扫描出待执行对象;

其中,所述第一配置信息为basepackage。

具体地,所述步骤s2包括:

s21、根据所述配置文件中的第一配置信息,确定所述业务代码中待扫描的类加载路径;

s22、根据所述类加载路径,扫描该类加载路径对应的每个类文件,判断所述类文件中是否包含添加注解的类;及

s23、当所述类文件中包含添加注解的类时,将所述添加注解的类作为待执行对象。

具体地,在启动springboot框架调用组件starter之前,业务开发人员明确业务代码涉及的中间件后,还需根据各中间件对应的组件starter指定的注解(annotation),预先在业务代码中对需要增强的方法(method)或类上进行标注,确定需要注入或增强的组件类。只有当业务代码中需要注入或增强的组件类标注了注解标记时,这些组件类才会被组件扫描器扫描到spring容器中。

其中,注解标记包括:@component通用注解、@name通用注解、@repository持久化层组件注解、@service业务层组件注解、@controller控制层组件注解等。

需要说明的是,每种组件starter都对应着不同的注解。以中间件rocketmq为例,rocketmq是一种消息中间件,消息中间件会有消息处理的监听方法,需要实现rocketmq的一系列接口和相关的配置代码才可生效。其对应的rocketmq-starter目前只有@rmqconsumer这一中注解,因此,当业务代码中涉及到中间件rocketmq时,针对rocketmq-starter,仅需在业务代码中标注@rmqconsumer这一种注解,通过标注@rmqconsumer这一注解,可以将method增强为rocketmq的消费者。另外,在标注@rmqconumser这一注解后,只需要像写普通方法那样去业务代码即可,框架会将其包装成一个消费消息处理的监听方法。

例如,当@rmqconsumer这一注解分别标注在类rocketmqexamples和方法test1和test3上面,说明该类的test1方法和test3方法是要被增强为rocketmq的消费者方法的。

s3、从第二路径中获取项目对象模型文件,读取所述配置文件中的第二配置信息,根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作,并进行组件增强及注入。

其中,所述第二配置信息是某个类或方法的个性化配置信息,例如,test1方法监听的标签(tag)是a,test2方法监听的标签(tag)是b。

具体的,所述“根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作”的步骤包括:

s31、根据所述项目对象模型文件中的坐标信息,从预设仓库中获取所述待执行对象对应的组件自动初始化程序的依赖;

s32、根据所述待执行对象对应的组件自动初始化程序的依赖,确定所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合;及

s33、根据所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合及所述第二配置信息,执行组件装配操作。

其中,项目对象模型(programobjectmodel,pom)文件用于定义中间件与第三方组件、中间件与中间件的依赖关系。因此,需预先在pom文件中引入相关组件starter的依赖。

例如,pom文件中包含启动rocketmq消费者服务这一中间件的所有依赖。具体地,启动中间件rocketmq的依赖包括:

windcharger-base表示一些基础工具包的依赖;

windcharger-serialzer表示消息体处理需要的序列化工具类依赖;

rocketmq-client表示消费者客户端组件相关的依赖;及

rocketmq-srvutils,rocketmq-tools表示rocketmq相关的工具类依赖。

在pom文件中,确定启动中间件rocketmq需要依赖的其他中间件及第三方组件后,需确定所述其他中间件及第三方组件的坐标信息,供后续利用该坐标信息找到相应的其他中间件及第三方组件并进行组件装配。

其中,所述坐标信息为maven坐标,maven的世界是拥有非常多的java构件的,可能是jar、可能是war、也可能是其他的一些东西。利用maven坐标唯一标识每一个构件(包括中间件、第三方组件)。

maven的坐标元素包括groupid、artifactid、version、packaging、classfier。只要我们提供正确的坐标元素,maven就能找到对应的构件。

所述预设仓库为:本地仓库和/或远程仓库和/或中央仓库。首先从本地仓库查找,没有的话从远程仓库下载。如果没有配置远程仓库,会默认从中央仓库地址(http://repo1.maven.org/maven2)下载构件,该中央仓库包含了世界上大部分流行的开源项目构件,但不一定所有构件都有。

例如,在一个依赖的maven坐标中:

groupid通常表示该依赖包属于哪个组织的哪个模块;

artifactid在groupid下的表示一个单独依赖包的唯一标识符;及

version表示一个依赖包的特定版本(例如:开发版本、内测版本或正式版本)。

利用上述步骤获取待执行对象对应的组件starter的依赖之后,对所有依赖进行去重处理,以确定待执行对象对应的组件starter需要依赖的其他中间件及第三方组件的依赖最小集合。

每个组件的装配规则及过程都不一样,组件装配需要的配置项从配置文件中读取。以中间件rocketmq为例,第二配置信息中需要配置的配置项包括:消费者线程数、消费者组名、消息服务器地址等。

根据所述第二配置信息以及待执行对象对应的组件starter需要依赖的其他中间件及第三方组件的依赖最小集合,进行组件装配操作,组件装配操作完成后,进行组件增强及注入,并将装配完成后的组件注册到spring容器中。组件增强及注入的方法为本领域人员习知技术手段,在此不作赘述。

上述实施例提出的中间件自动扫描装配方法,通过提供标准pom文件规范中间件与第三方组件、中间件与中间件之间的依赖关系,最大程度上降低jar包冲突的风险;预先定义各种注解来对业务代码进行标注,通过组件扫描器来完成功能的增强和注入;业务代码中不需要增加组件starter的接口,只需增加指定组件的注解即可使用,通过注解来实现功能的“内聚”;通过解决组件依赖和自动装配问题达到了简化项目配置,减少了使用代码量,提高开发效率。

本发明还提供一种电子装置。参照图2所示,为本发明电子装置1较佳实施例的示意图。

在本实施例中,电子装置1可以是服务器、智能手机、平板电脑、便携计算机、桌上型计算机等具有数据处理功能的终端设备,所述服务器可以是机架式服务器、刀片式服务器、塔式服务器或机柜式服务器。

该电子装置1包括存储器11、处理器12,通信总线13,及网络接口14。

其中,存储器11至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,sd或dx存储器等)、磁性存储器、磁盘、光盘等。存储器11在一些实施例中可以是所述电子装置1的内部存储单元,例如该电子装置1的硬盘。存储器11在另一些实施例中也可以是所述电子装置1的外部存储设备,例如该电子装置1上配备的插接式硬盘,智能存储卡(smartmediacard,smc),安全数字(securedigital,sd)卡,闪存卡(flashcard)等。进一步地,存储器11还可以既包括该电子装置1的内部存储单元也包括外部存储设备。

存储器11不仅可以用于存储安装于该电子装置1的应用软件及各类数据,例如中间件自动扫描装配程序10、预先配置的配置文件(图中未标识)及项目对象模型文件(图中未标识)等,还可以用于暂时地存储已经输出或者将要输出的数据。

处理器12在一些实施例中可以是一中央处理器(centralprocessingunit,cpu)、控制器、微控制器、微处理器或其他数据处理芯片,用于运行存储器11中存储的程序代码或处理数据,例如中间件自动扫描装配程序10等。

通信总线13用于实现这些组件之间的连接通信。

网络接口14可选的可以包括标准的有线接口、无线接口(如wi-fi接口),通常用于在该电子装置1与其他电子设备之间建立通信连接。

图2仅示出了具有组件11-14的电子装置1,本领域技术人员可以理解的是,图2示出的结构并不构成对电子装置1的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。

可选地,该电子装置1还可以包括用户接口,用户接口可以包括显示器(display)、输入单元比如键盘(keyboard),可选的用户接口还可以包括标准的有线接口、无线接口。

可选地,在一些实施例中,显示器可以是led显示器、液晶显示器、触控式液晶显示器以及有机发光二极管(organiclight-emittingdiode,oled)触摸器等。其中,显示器也可以称为显示屏或显示单元,用于显示在电子装置1中处理的信息以及用于显示可视化的用户界面。

在图2所示的电子装置1实施例中,作为一种计算机存储介质的存储器11中存储中间件自动扫描装配程序10的程序代码,处理器12执行中间件自动扫描装配程序10的程序代码时,实现如下步骤:

a1、接收业务代码依赖的框架调用组件starter的启动命令,从第一路径中获取预设的配置文件,其中,配置文件中包括:所述业务代码中涉及到的各中间件及所述各中间件必要的配置信息;

在本实施例中,以中间件rocketmq为例,但不仅限于中间件rocketmq,对本发明方案进行说明。

所述框架为springboot框架,业务开发人员基于springboot框架写入业务代码。所述组件自动初始化程序是将某些组件初始化操作自动化进行的程序,以下简称组件starter。

在启动springboot框架调用组件starter之前,需预先配置业务相关中间件的配置项,生成配置文件,并将配置文件保存至预设的第一路径中。其中,所述配置文件为yml文件,yml文件格式是yaml(yamlaintmarkuplanguage)编写的文件格式,yaml是一种直观的能够被电脑识别的的数据数据序列化格式,并且容易被人类阅读,容易和脚本语言交互的,可以被支持yaml库的不同的编程语言程序导入。

业务开发人员在写入业务代码时,可明确业务代码中涉及的中间件,例如,当业务代码中涉及中间件rocketmq时,需预先在配置文件中根据rocketmq-starter的要求对中间件rocketmq的配置项进行设置。

例如,针对中间件rocketmq在配置文件中预先设置的配置项包括:

rocketmq.group.name,表示消费者的组名;

rocketmq.consumer.minthread,表示消费者的最小线程数;

rocketmq.consumer.maxthread,表示消费者的最大线程数;

rocketmq.consumer.basepackage,表示需要被增强为消费者方法的包路径名;

rocketmq.domain.name,表示消费服务器的地址。

a2、读取所述配置文件中的第一配置信息,根据所述第一配置信息,从所述业务代码中扫描出待执行对象;

其中,所述第一配置信息为basepackage;

具体地,所述步骤a2包括:

a21、根据所述配置文件中的第一配置信息,确定所述业务代码中待扫描的类加载路径;

a22、根据所述类加载路径,扫描该类加载路径对应的每个类文件,判断所述类文件中是否包含添加注解的类;及

a23、当所述类文件中包含添加注解的类时,将所述添加注解的类作为待执行对象。

具体地,在启动springboot框架调用组件starter之前,业务开发人员明确业务代码涉及的中间件后,还需根据各中间件对应的组件starter指定的注解(annotation),预先在业务代码中对需要增强的方法(method)或类上进行标注,确定需要注入或增强的组件类。只有当业务代码中需要注入或增强的组件类标注了注解标记时,这些组件类才会被组件扫描器扫描到spring容器中。

其中,注解标记包括:@component通用注解、@name通用注解、@repository持久化层组件注解、@service业务层组件注解、@controller控制层组件注解等。

需要说明的是,每种组件starter都对应着不同的注解。以中间件rocketmq为例,rocketmq是一种消息中间件,消息中间件会有消息处理的监听方法,需要实现rocketmq的一系列接口和相关的配置代码才可生效。其对应的rocketmq-starter目前只有@rmqconsumer这一中注解,因此,当业务代码中涉及到中间件rocketmq时,针对rocketmq-starter,仅需在业务代码中标注@rmqconsumer这一种注解,通过标注@rmqconsumer这一注解,可以将method增强为rocketmq的消费者。另外,在标注@rmqconumser这一注解后,只需要像写普通方法那样去业务代码即可,框架会将其包装成一个消费消息处理的监听方法。

例如,当@rmqconsumer这一注解分别标注在类rocketmqexamples和方法test1和test3上面,说明该类的test1方法和test3方法是要被增强为rocketmq的消费者方法的。

a3、从第二路径中获取项目对象模型文件,读取所述配置文件中的第二配置信息,根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作,并进行组件增强及注入。

其中,所述第二配置信息是某个类或方法的个性化配置信息,例如,test1方法监听的标签(tag)是a,test2方法监听的标签(tag)是b。

具体的,“根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作”的步骤包括:

a31、根据所述项目对象模型文件中的坐标信息,从预设仓库中获取所述待执行对象对应的组件自动初始化程序的依赖;

a32、根据所述待执行对象对应的组件自动初始化程序的依赖,确定所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合;及

a33、根据所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合及所述第二配置信息,执行组件装配操作。

其中,项目对象模型(programobjectmodel,pom)文件用于定义中间件与第三方组件、中间件与中间件的依赖关系。因此,需预先在pom文件中引入相关组件starter的依赖。

例如,pom文件中包含启动rocketmq消费者服务这一中间件的所有依赖。具体地,启动中间件rocketmq的依赖包括:

windcharger-base表示一些基础工具包的依赖;

windcharger-serialzer表示消息体处理需要的序列化工具类依赖;

rocketmq-client表示消费者客户端组件相关的依赖;及

rocketmq-srvutils,rocketmq-tools表示rocketmq相关的工具类依赖。

在pom文件中,确定启动中间件rocketmq需要依赖的其他中间件及第三方组件后,需确定所述其他中间件及第三方组件的坐标信息,供后续利用该坐标信息找到相应的其他中间件及第三方组件并进行组件装配。

其中,所述坐标信息为maven坐标,maven的世界是拥有非常多的java构件的,可能是jar、可能是war、也可能是其他的一些东西。利用maven坐标唯一标识每一个构件(包括中间件、第三方组件)。

maven的坐标元素包括groupid、artifactid、version、packaging、classfier。只要我们提供正确的坐标元素,maven就能找到对应的构件。

所述预设仓库为:本地仓库和/或远程仓库和/或中央仓库。首先从本地仓库查找,没有的话从远程仓库下载。如果没有配置远程仓库,会默认从中央仓库地址(http://repo1.maven.org/maven2)下载构件,该中央仓库包含了世界上大部分流行的开源项目构件,但不一定所有构件都有。

例如,在一个依赖的maven坐标的示例图。其中:

groupid:通常表示该依赖包属于哪个组织的哪个模块;

artifactid:在groupid下的表示一个单独依赖包的唯一标识符;及

version:表示一个依赖包的特定版本(例如:开发版本、内测版本或正式版本)。

利用上述步骤获取待执行对象对应的组件starter的依赖之后,对所有依赖进行去重处理,以确定待执行对象对应的组件starter需要依赖的其他中间件及第三方组件的依赖最小集合。

每个组件的装配规则及过程都不一样,组件装配需要的配置项从配置文件中读取。以中间件rocketmq为例,第二配置信息中需要配置的配置项包括:消费者线程数、消费者组名、消息服务器地址等。

根据所述第二配置信息以及待执行对象对应的组件starter需要依赖的其他中间件及第三方组件的依赖最小集合,进行组件装配操作,组件装配操作完成后,进行组件增强及注入,并将装配完成后的组件注册到spring容器中。组件增强及注入的方法为本领域人员习知技术手段,在此不作赘述。

上述实施例提出的电子装置1,通过提供标准pom文件规范中间件与第三方组件、中间件与中间件之间的依赖关系,最大程度上降低jar包冲突的风险;预先定义各种注解来对业务代码进行标注,通过组件扫描器来完成功能的增强和注入;业务代码中不需要增加组件starter的接口,只需增加指定组件的注解即可使用,通过注解来实现功能的“内聚”;通过解决组件依赖和自动装配问题达到了简化项目配置,减少了使用代码量,提高开发效率的目的。

可选地,在其他的实施例中,中间件自动扫描装配程序10还可以被分割为一个或者多个模块,一个或者多个模块被存储于存储器11中,并由一个或多个处理器(本实施例为处理器12)所执行,以完成本发明,本发明所称的模块是指能够完成特定功能的一系列计算机程序指令段。例如,参照图3所示,为图2中中间件自动扫描装配程序10的模块示意图,在该实施例中,中间件自动扫描装配程序10可以被分割为接收模块110、扫描模块120及装配模块130,所述模块110-130所实现的功能或操作步骤均与上文类似,此处不再详述,示例性地,例如其中:

接收模块110,用于接收业务代码依赖的框架调用组件自动初始化程序的命令,从第一路径中获取预设的配置文件,其中,配置文件中包括:所述业务代码中涉及到的各中间件及所述各中间件必要的配置信息;

扫描模块120,用于读取所述配置文件中的第一配置信息,根据所述第一配置信息,从所述业务代码中扫描出待执行对象;及

装配模块130,用于从第二路径中获取项目对象模型文件,读取所述配置文件中的第二配置信息,根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作,并进行组件增强及注入。

此外,本发明实施例还提出一种计算机可读存储介质,所述计算机可读存储介质中包括中间件自动扫描装配程序10,所述中间件自动扫描装配程序10被处理器执行时实现如下操作:

a1、接收业务代码依赖的框架调用组件自动初始化程序的命令,从第一路径中获取预设的配置文件,其中,配置文件中包括:所述业务代码中涉及到的各中间件及所述各中间件必要的配置信息;

a2、读取所述配置文件中的第一配置信息,根据所述第一配置信息,从所述业务代码中扫描出待执行对象;及

a3、从第二路径中获取项目对象模型文件,读取所述配置文件中的第二配置信息,根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作,并进行组件增强及注入。

优选地,所述步骤a2包括:

a21、根据所述配置文件中的第一配置信息,确定所述业务代码中待扫描的类加载路径;

a22、根据所述类加载路径,扫描该类加载路径对应的每个类文件,判断所述类文件中是否包含添加注解的类;及

a23、当所述类文件中包含添加注解的类时,将所述添加注解的类作为待执行对象。

优选地,所述步骤a3中的“根据所述项目对象模型文件、第二配置信息及所述待执行对象,执行组件装配操作”包括:

a31、根据所述项目对象模型文件中的坐标信息,从预设仓库中获取所述待执行对象对应的组件自动初始化程序的依赖;

a32、根据所述待执行对象对应的组件自动初始化程序的依赖,确定所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合;及

a33、根据所述待执行对象对应的组件自动初始化程序需要依赖的依赖最小集合及所述第二配置信息,执行组件装配操作。

优选地,所述框架为springboot框架。

优选地,所述项目对象模型文件用于定义中间件与第三方组件、中间件与中间件的依赖关系。

本发明之计算机可读存储介质的具体实施方式与上述中间件自动扫描装配方法的具体实施方式大致相同,在此不再赘述。

上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。

需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、装置、物品或者方法不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、装置、物品或者方法所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、装置、物品或者方法中还存在另外的相同要素。

通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在如上所述的一个存储介质(如rom/ram、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。

以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其它相关的技术领域,均同理包括在本发明的专利保护范围内。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1