威尼斯人棋牌-威尼斯欢乐娱人城-首页

集成适配器管理系统和方法

文档序号:6607376
专利名称:集成适配器管理系统和方法
技术领域
本申请涉及应用集成,更具体地,涉及用于促进诸如不同类型App应用的技术之间的技术之间的互操作性和/或互连性的系统和方法。
背景技术
用于促进App应用之间的互操作性的系统和方法在那些大型企业常常使用包括必须高效地互相通信的较旧的旧式应用和第三方应用的各种不同的应用的企业环境(包括企业应用集成(EAI)实现)中特别重要。例如,大型企业可以使用必须互相通信以完成某些任务的不同的企业资源计划(ERP)、客户关系管理(CRM)、供应链管理(SCM)及其他App。企业可能希翼使用第一App应用来实行某一任务,但是,该任务可能要求访问第二App应用的数据或功能。一般而言,第一App应用可以通过也叫做集成接口的特殊转换接口与第二App应用进行通信,该转换接口促进转换由不同类型的App使用的不同类型的消息。当一个App应用在计算环境中与一个或多个其他App应用接口时,该App应用被称为与其他App应用集成。为集成可在不同的技术平台上运行的诸如不同的ERP/CRM应用之类的不同的旧式应用和第三方应用,可以使用Oracle应用集成体系结构(AIA)基础包和伴随的适配器。 所包括的适配器可以提供诸如Oracle E-Business Suite (甲骨文电子商务套件)中所包括的应用之类的各种应用之间的双向和多模同步和异步互连性。在某些实现方式中,可能不清楚应该如何以及何时使用已经可用的适配器或新适配器来实现App应用之间的无缝且最佳的性能集成。相应地,常常雇佣解决方案提供商来构建适当的集成解决方案。然而,这会很费时并且成本高。此外,被承包的集成解决方案可以是冗余的,并可能导致使用不同或不兼容方法的不同解决方案,即,被承包的解决方案可能缺乏实现方式的一致性。另外,对商务App套件或计算体系结构的进一步的更改或更新可能要求额外地构建潜在高成本的集成解决方案。

发明内容
用于管理用于集成App应用的适配器和连接器的示例集成适配器管理系统包括连接器储存库。每一个连接器都包括一个或多个集成适配器。连接器生成器与连接器储存库进行通信,并适于响应于检测到在连接器储存库中找不到对应的连接器的事件,有选择地生成一个或多个连接器。在更具体的示例实施例中,连接器生成器适于将一个或多个所生成的连接器实现为Web服务。连接器生成器可以根据甲骨文企业的应用集成体系结构(AIA)集成框架来构建。示例系统还包括用于监视与连接器相关联的运行时信息并作为响应提供运行时信息的连接器监视器。反馈系统维护涉及连接器储存库中的一个或多个连接器的操作的反馈信息。一个或多个用户接口模块促进允许用户向反馈系统提供反馈,并查看由连接器监视器所提供的运行时信息。搜索引擎适于促进使得用户能够使用一个或多个用户接口来对连接器的储存库实行搜索,以搜索所希翼的连接器。内省系统促进检测连接器储存库中的定制或扩展的适配器,并作为响应,向一个或多个用户接口模块提供指示。此处所公开的某些实施例可以促进连接器和适配器的自动生成,以促进集成企业或其他组织的App应用。基于连接器元数据来自动生成连接器可以改善所生成的连接器的一致性,并可以促进避免创建冗余的连接器。此外,这样的功能还可以促进过渡到新技术, 因为可以随着企业计算环境的变化而自动地重新生成或更新所生成的连接器。诸如反馈用户接口、可搜索的连接器储存库,以及连接器运行时监视器之类的各种工具促进管理何时以及如何生成和使用连接器,并进一步促进确定在给定情况下要使用的最佳连接器。通过参考说明书的其余部分和附图,可以对此处所公开的特定实施例的特征和优
点取得进一步的理解。


图1是示出用于促进App集成功能的管理和控制的系统的第一示例实施例的图形。图2是图1的示例系统的更详细的图。图3是表征图1-2的系统的示例进程流的流程图。图4描绘了表征图1-2的系统的连接器进程流和相关联的命令、参数、服务,以及反馈过程之间的示例关系的示例实体关系(ER)图。图5是适用于与图1-2的系统一起使用的示例一般化方法的流程图。
具体实施例方式虽然是关于特定实施例来描述本发明的,但是,这些特定实施例只是说明性的,而不是限制性的。例如,尽管此处是关于涉及使用Oracle E-Business Suite及Oracle企业的其他产品的实现方式来讨论某些实施例的,但是,实施例不仅限于此。例如,使用促进使不同应用接口的各种适配器的任何企业应用集成(EAI)框架都可受益于搜索适配器、生成包括适配器的连接器,监视适配器,以及记录根据此处所公开的某些实施例的适配器和连接器的反馈的能力。为了当前的讨论,诸如App应用的应用可以是适于实行一个或多个功能或任务或其组合的任何计算机可读指令的集合。如果第一应用和第二应用之间的通信能够通过接口得以实现,则第一应用被称为与第二App应用接口或集成,反之亦然。示例接口包括一个适配器或适配器的集合(例如,连接器),它可将来自第一应用的第一类型的特定消息转换为一般性消息,然后,将该一般性消息转换为可由第二App应用读取的第二类型的特定消息。 连接器还可以通过向一般性类型的消息的中间转换,将第二特定类型的消息转换为第一特定类型的消息。应注意,如果第一应用或第二应用适于读取该一般性消息,则可以省略一个或多个消息变换步骤。一般性消息类型可以是用于在各种不同类型的消息之间进行转换的消息类型。可以将一般性消息用作接口过程期间的中间消息。此外,还应注意,可以读取该一般性消息类型的某些App应用可以不要求在一般性消息和App应用所使用的不同的特定消息之间进行额外的转换。一般而言,企业应用集成(EAI)涉及促进不同的应用、进程、系统,以及技术之间的交互。EAI可以被可视化为用于跨企业集成计算资源的集成框架。这样的计算资源的实例包括供应链管理(SCM)应用(例如,用于管理库存和装运)、客户关系管理(CRM)应用 (例如,用于管应当前和潜在客户)、商务智能(Bi)应用(例如,用于从现有操作数据中查找模式),及其他类型的应用。这些应用可能缺乏用于相互进行通信的内建机制。相应地, 不存在集成,应用可能不能共享数据和功能。在应用之间缺乏集成以及伴随的缺乏相互通信能力会导致效率低下。例如,相同的数据可以存储在多个地点,或者,涉及多个功能/进程的某些进程流可能无法自动化。为集成App应用,可以使用EAIApp来链接一个机构内的应用,以简化和自动化业务进程,而常常消除了显著改变现有应用或数据结构的需要。EAI系统经常面临的一个挑战是,要求集成的各种系统和应用常常驻留在不同的操作系统上,使用不同的数据库解决方案和不同的计算机语言,或包括旧式系统。如果在不遵循结构化的EAI方法的情况下应用集成,则点到点连接可能跨机构生长,导致不希翼的连接和依赖关系的复杂的网。EAI经常涉及系统的分析系统,这可涉及以多个级别嵌入网络中的多个异种且分布式的系统所存在的大规模的跨学科问题。一般而言,EAI系统可以被分类为调停系统、联合系统,或其组合。调停EAI系统可以充当多个应用之间的接口代理,以促进多个应用之间的数据和进程的共享。当在集成的应用中发生某一事件时,例如,添加新信息、完成新事务,等等,EAI系统中的集成模块检测到该事件,或被通知该事件。然后,集成模块向相关的应用传播必要的信息或指令。联合EAI系统可以充当多个应用之间的总接口面。在这样的系统中,从一个应用到另一个应用的事件调用被EAI系统置于前端,以便EAI系统将底层应用的仅相关信息和接口暴露给其他应用。这样的EAI系统可以代表叫做“消费者”的请求者应用来与交互操作接口。一般而言,对于提供服务,即,Web服务的应用之间的交互中的每一步骤,如在面向服务体系结构(SOA)环境中,两个服务中的一个(消费者服务)启动请求,而另一个服务(生产者)实行该请求。启动请求的服务叫做消费者服务,而实行请求的服务叫做生产者服务或提供者服务。服务的角色可以在交互的过程中转换。调停和联合可以被视为伴随的集成体系结构的EAI模式。在单一 EAI系统中可以并行地使用这些模式。例如,这样的EAI系统可以使多个应用保持同步(调停),而服务于来自外部用户针对这些应用的请求(联合)。为清楚起见,图形中省略了诸如硬盘驱动器、处理器、操作系统、电源、路由器等等之类的某些已知的组件。然而,了解当前原理的本领域的技术人员将知道实现哪些组件以及如何实现它们以满足某个应用的需要。图1是示出系统10的第一示例实施例的图示,该系统用于促进诸如以连接器和适配器代表的功能之类的App集成功能的管理和控制,如下面更加全面地讨论的。系统10可以以在企业应用服务器上运行的App来实现。或者,系统10的各种组件可以以分布式方式跨诸如网络和服务器之类的各种不同的计算资源实现,而不只是在可被客户端系统访问的单一应用服务器上实现。系统10包括与诸如Oracle E-business Suite之类的App应用套件14进行通信的集成适配器管理系统12。商务套件14包括集成连接器储存库30和各种商务相关的应用32,各种商务相关的应用32彼此集成,并与诸如数据库16和中间件18的其他应用以及诸如第三方应用20的与之通信的应用集成。为了当前的讨论,第三方应用可以是与套件14 中所包括的商务应用32分开的任何App应用。本示例集成适配器管理系统12包括与连接器生成系统沈和用户接口App34进行通信的储存库控制模块22 ;与用户接口App34和连接器生成系统沈进行通信的反馈模块24,以及与用户接口App34、数据库16,以及中间件18进行通信的连接器监视器模块 28。注意,尽管用户接口App34被示为一个模块,但用户接口App34可以包括多个模块,如储存库控制接口、反馈接口,以及连接器监视器用户接口模块,如下面更加全面地讨论的。 用户接口App;34适于使得用户能够通过用户接口硬件36与集成适配器管理系统12进行交互,用户接口硬件36可以包括显示器和诸如鼠标、键盘等等之类的输入设备。为了当前的讨论,模块可以是功能的任何集合,可以包括一个或多个机器可实行的功能或过程。数据库模块16可以在数据库服务器上运行,并充当套件14的各种商务应用32的数据仓储设施。中间件18可以在面向服务体系结构(SOA)服务器上运行,并可以促进第三方应用20与套件14的商务应用32的进一步接口。在操作中,商务套件14包括用于实现Oracle应用集成体系结构(AIA)企业业务对象和服务层的计算机代码,包括由Oracle AIA基础包所提供的功能。连接器生成系统沈以与商务套件14中所提供的AIA功能一致的方式实现连接器和相关联的Web服务。为了当前的讨论,服务可以是任何Web服务,其中,Web服务可以是诸如由程序、函数、进程代表的任何功能,或可访问或通过利用网络发送的消息激活的其他功能。示例消息包括通过超文本传输协议(HTTP)通过网络发送的统一资源定位符(URL)。另一个示例消息包括根据简单对象访问协议(SOAP)发送的可扩展标记语言(XML)消息。Web服务可以以诸如Web服务描述语言(WSDL)、Java等各种语言编写。套件14的一个或多个商务应用32可以发出事件,以便从另一个应用检索数据,以使用另一个应用的功能来实行进程等等。在套件14的下层的AIA层促进从集成储存库30 中选择连接器,以响应于检测到事件而连接适当的应用。示例连接器包括Oracle E_biz产品连接器、发票连接器、帐目连接器等,用于在不同的应用中分别更新产品信息、发票信息、 帐目信息。可以包括诸如到达队列(AQ)事件适配器、表/视图适配器、对SQL的过程语言扩展(PLSQL)适配器、企业商务组织(EBO)适配器等的各种AIA模块,以促进应用数据和进程的集成。如果一个新App应用正在与商务套件14的商务应用32集成,则必须从储存库30 中选择适当的连接器,或以别的方式提供适当的连接器以促进要集成的相关命令、进程、参数和流的集成。对集成App应用感兴趣的用户可以使用用户接口App34来访问储存库控制模块22的功能。储存库控制模块22包括搜索引擎和相关联的功能以用于促进在集成储存库30中搜索一个或多个适当的连接器以促进App应用的集成。注意,搜索集成连接器储存库30可以在检测到由要被集成的应用所提供的事件时自动实行,而不会偏离本公开的范围。
8
储存库控制模块22包括连接器元数据储存库,如下面更加全面地讨论的,该连接器元数据储存库使得用户能够使用用户接口App34输入描述集成特定App应用所需的一个或多个连接器的一个或多个特征的数据。连接器元数据可由连接器生成系统沈访问。连接器生成系统沈适于使用元数据自动生成一个或多个适当的连接器。然后,连接器作为连接器服务对应用可用。对应于新生成的连接器的App代码可以存储在集成连接器储存库30 中。在本实施例中,连接器生成系统沈诸如通过将连接器生成系统沈耦合到应用套件14的可扩展标记语言(XML)网关,使所生成的连接器作为Web服务对其他应用可用。连接器生成系统沈包括用于检测事件的事件适配器,事件包括来自应用套件14的XML调用、 API调用,以及DB调用。响应于检测到事件,可以由连接器生成系统沈提供适当的连接器以用于接口应用,如下面更加全面地讨论的。注意,可以由应用套件14中所包括的AIA功能自动确定或估计(而不是手动输入)从储存库控制模块22提供到连接器生成系统沈的连接器元数据,而不会偏离本公开的范围。—个给定用户可以通过使用用户接口App34来描述他们的涉及使用给定连接器来实行特定集成功能的体验或观察,以更新由反馈模块M维护的反馈日志。用户还可以根据预定的评定标度或方法来对连接器进行评定。这使得使用储存库控制模块22的用户能够选择用于应用集成的连接器,以查看涉及集成连接器储存库30中所包括的特定连接器的其他用户的注释、连接器评定等等。当一个给定连接器运行时,取决于正在被集成的连接器和应用,可以由数据库模块16和/或中间件18来确定对应的连接器运行时信息。通常,数据库16将维护对象的运行时信息,而中间件18将跟踪服务的运行时信息。可通过连接器监视器模块观访问此运行时信息,并使得此运行时信息通过用户接口App34对系统10的用户可用。连接器运行时信息可以用来诊断连接器问题,并促进将提供到反馈模块M的反馈通知给用户。为了当前的讨论,中间件可以是适于一个或多个不同应用之间的接口通信的任何App应用或应用的集合。连接器生成系统沈还可以使用通过反馈模块M提供的诸如连接器评定之类的信息,以促进选择要包括在特定的生成的连接器中的适配器。所生成的连接器可包括多个适配器以实现进程流或与连接器相关联的集成功能。 在本特定实施例中,连接器生成系统沈专门适于与应用套件14 一起使用,这可以通过Oracle E-Business Suite来实现。连接器生成系统洸是根据可通过Oracle企业获得的Oracle企业的AIA集成标准和E-Business Suite最佳实践构建的。通过连接器生成系统沈生成诸如E-Business Suite连接器之类的各种连接器,并作为Web服务来展示,连接器生成系统沈可以构建于由Oracle企业所提供的现有的电子商务适配器和AIA辅件生成器的顶部。尽管在本实施例中,连接器储存库控制模块22是与集成连接器储存库30分开示出的,但是应注意,集成连接器储存库30和储存库控制模块22可以被视为单一模块或储存库系统的一部分,而不会偏离本公开的范围。一般而言,此处所讨论的各种模块可以组合起来或以分布式方式实现,而不会偏离本公开的范围。集成连接器储存库30包括套件14中所包括的预建的连接器,并且还可以包括由连接器生成系统26所生成的连接器。可以作为用户接口App34的用户接口模块而包括的动态内省系统可以检测所有定制编写或扩展的电子商务套件适配器。为了当前的讨论,内省系统可以是适用、于确定连接器和/或适配器的一个或多个特征的任何系统或模块。用户可以基于什么(例如,什么对象)、何时(例如,何时发生事件),以及如何(例如,应该如何使用数据),使用用户接口App34和硬件36来浏览和搜索储存库30。应注意, 诸如Oracle E-Business Suite连接器之类的连接器可以包括一起工作以实现特定集成功能的一组 Oracle E-Business Suite 适配器。一般而言,为了当前的讨论,集成适配器可以是对于特定任务,如检索特定数据或实行某一进程,用于促进第一应用和第二应用之间的通信的App程序或其他计算机可读指令集。因此,适配器可以促进应用之间的双向通信。适配器可以是专用于特定应用或应用类别的。诸如消息队列、Web服务或专有协议之类的各种技术都可以用于存进实现适配器。 连接器可以是一起工作以实现特定集成功能的适配器的任何集合,所述特定集成功能可包括由不同的适配器处理的也叫做“流”的一系列任务。只使用一个适配器的连接器也被视为适配器。连接器监视器28适于维护连接器的运行时信息。可以从中间件18和伴随的SOA 服务器并从数据库16和伴随的数据库服务器收集运行时信息。与用户接口App34相结合的连接器监视器观适于使得用户能够不仅监视给定连接器的运行时性能,而且还监视连接器所使用的格个适配器服务的性能和运行时信息。反馈模块24 (在本实施例中,也可以叫做电子商务套件连接器反馈系统),使得用户能够(通过用户接口App34)对于连接器的有用性进行评定,并共享有关每一连接器的反馈和建议。可以通过连接器生成系统26或通过更直接的链路将反馈提供回集成储存库 30。可以由不同的解决方案提供商通过用户接口App34查看反馈。应注意,尽管在本实施例中,维护用户反馈的反馈日志包含在反馈模块M中,但是,此反馈日志可以位于别处,如在集成连接器储存库30中,而不会偏离本公开的范围。应注意,各种适配器和连接器,比如集成储存库30中所包括的,可以包括用于将由不同的App应用所提供的特定类型的消息转换为一般性消息的机器可读指令。然后,适配器可以根据需要将一般性消息,例如,应用集成体系结构(AIA)格式消息,转换为供特定应用使用所需的适当的特定消息(例如,电子商务应用特定消息)。图2是图1的示例系统10的比较详细的图形。用户接口App34被示为包括与连接器储存库用户接口模块40、连接器反馈用户接口模块48,以及连接器监视器用户接口模块50进行通信的浏览器接口 96,为了说明,这些模块也为示为分别包括在储存库控制模块 22、反馈模块对,以及连接器监视器模块观中。浏览器接口 96包括用于使得用户能够有选择地访问由其他接口模块40、48、50所提供的接口功能的机器可读指令。储存库控制模块22还包括与搜索引擎80进行通信的连接器储存库搜索模块42。 搜索引擎80与集成储存库30进行通信,并促进响应于通过连接器储存库用户接口模块40 触发的搜索而实现连接器和适配器搜索。 储存库搜索模块42也与储存库控制模块22中的连接器元数据储存库46进行通信,也可通过连接器储存库用户接口模块40和连接器储存库搜索模块42搜索连接器元数据储存库46。连接器元数据储存库46进一步与连接器储存库用户接口模块40进行通信。用户可以使用连接器储存库用户接口模块40来查看、浏览、和/或搜索元数据储存库46的内容,并添加涉及给定连接器和/或适配器的元数据。为了当前的讨论,连接器元数据可以是表征或描述连接器或适配器的任何信息,包括但不仅限于与其相关联的命令、参数、流, 以及定时或同步信息。反馈模块M还包括反馈日志92,用于维护涉及诸如App应用套件14的应用之类的应用所使用的连接器和/或适配器服务的用户反馈。反馈可以包括根据预定的评定标度所进行的连接器评定。另外,由服务反馈日志92维护的反馈信息可以指出给定连接器是否丢失功能,是否它正在适当地被实现,需要向连接器中添加什么功能等等。服务反馈日志92 与连接器反馈模块48和连接器生成系统沈的连接器代码生成器56进行通信。在示例操作情形下,假设正在搜索连接器的一个人(用户)是特定企业,例如沃尔玛的解决方案提供者,而该用户正在搜索发票连接器,即用于促进在商务应用32之间共享发票信息的连接器。用户可以查看由日志92维护的连接器反馈信息,以帮助确定用于要被集成的特定应用的优选发票连接器。连接器代码生成器56进一步与连接器元数据储存库46进行通信。连接器代码生成器56可以从元数据储存库46接收连接器元数据,以促进根据元数据构建一个或多个所希翼的连接器和/或适配器。连接器生成系统沈还包括与连接器代码生成器56进行通信的连接器服务模块 58。连接器服务模块58的细节是应用特定的,并可以随着特定实现方式而变化。本领域的技术人员将了解本公开。连接器服务模块58适于将由连接器代码生成器56所生成的连接器公布(例如, 通过适配器60-66)为Web服务,以供应用套件14和伴随的商务应用32使用。在本特定实施例中,连接器服务模块58利用各种现有的技术和工具将所生成的连接器74作为Web服务公布给不同的应用。这些技术包括事件适配器60、可扩展标记语言(XML)适配器62、应用编程接口(API)适配器64,以及数据库(DB)适配器66。适配器60-66与Oracle生产者商业流程实行语言(BPEL)过程管理(PM)模块68进行通信,该模块68向Oracle消费者企业服务总线(ESB)模块70提供输出(例如,基于活动的管理(ABM)输出)。消费者ESB模块70与变换BPEL PM模块72通信。生产者BPEL PM模块68促进为给定连接器构建生产者web服务适配器。在本示例实施例中,使用生产者适配器来将由生产者应用所生成的消息转换为一般性应用集成体系结构(AIA)消息,反之亦然。类似地,消费者适配器可以将消息从消费者应用转换为AIA 消息,并且反之亦然。一般而言,可以使用BPEL来将各种完全不同的功能或进程联合或集成为集成的进程或流。BPEL可以促进因特网和/或其他网络的无缝使用,以促进进行诸如货币兑换、资产重新分配等的业务事务。变换BPEL模块72促进生成变换服务,将与生产者适配器相关联的生产者服务链接到与消费者适配器相关联的消费者服务。然后,通过存储在元数据储存库46中的元数据表征所产生的编排的连接器服务。然后,根据需要,由套件14的生产者和消费者应用使用连接器服务和伴随的元数据。可以响应于诸如来自套件14的应用的统一资源定位符(URL) 调用之类的事件,激活由连接器服务模块58所提供的连接器服务。为了说明的目的,连接器服务模块58的各种适配器60-66被示为与应用套件14中所包括的对应的集成技术进行通信。示例技术包括与连接器服务模块58的事件适配器 60进行通信的Oracle商务事件系统(BES) 76和伴随的到达队列(AQ) 78。XML网关82将 XML适配器62与BES 76和接口视图/表模块84进行接口。BES 76被示为与套件14的应用32进行通信。应注意,应用32可以包括诸如客户关系管理(CRM)、供应链管理(SCM)等的各种企业资源计划(ERP)应用,如可以包括在例如Oracle的应用电子商务套件中的。BES 76包括促进检测由一个或多个应用32所发出的事件的机器可读指令。事件可以对应于需要连接器服务以促进消息转换的那些发出的消息,如下面更加全面地讨论的。BES 76可以通过诸如Oracle BES的应用服务来实现,该应用服务与Oracle Workflow 一起提供,并使用Oracle高级队列技术来在系统和应用之间传递业务事件。BES 76适于支撑并促进基于消息的点到点系统集成、系统集成消息传送中心,以及分布式应用消息传送。API适配器64与对结构化查询语言的过程语言扩展(PLSQL)应用编程接口(API) 模块90和并行程序模块86进行通信。并行程序模块86与I3ass表88和接口视图/表模块84进行通信。DB适配器66与接口视图/表模块84和BES模块76的AQ模块78进行通当诸如消费者应用之类的应用调用(诸如通过URL)由连接器服务模块58所提供的连接器服务时,相关联的连接器运行。连接器服务的运行促进消费者应用通过转换消息与生产者应用接口。由数据库16和中间件18收集涉及连接器的运行时信息。连接器监视器模块观中所包括的集成DB对象运行时模块M组织和维护从数据库16中获取的连接器运行时信息。然后,可通过连接器监视器用户接口模块50来访问所维护的DB连接器运行时信息。类似地,由中间件18所获得的连接器运行时信息可通过连接器监视器模块观中所包括的集成服务对象运行时模块52访问。集成服务对象运行时模块52与连接器监视器用户接口模块50进行通信,以促进用户访问和查看由连接器监视器用户接口模块50组织和维护的连接器运行时信息。元数据储存库46可以包括连接器信息,例如,什么流、命令、参数,及其他相关信息用于生成特定连接器。一个示例,连接器可以是“创建订单”、“更新订单信息”、“取消订单”、“创建客户记录”、“更新客户记录”等。每个连接器在一般性类型消息与应用特定的消息之间进行转换,以促进在应用之间实现连接器和共享功能和/或数据。在连接器是用于在应用之间共享订单信息的“创建订单”连接器的示例情形下,应注意,一个数据库可以具有与另一个数据库不同的订单信息的组织。该连接器促进不同的订单数据结构之间的映射。在用户编码一个特定集成任务的新连接器之前,用户可以轻松地使用储存库控制模块22来在集成储存库30和连接器元数据储存库46中搜索合适的连接器。这有助于避免连接器的冗余创建。概括地说,系统10可以被视为包括下列各项的集成适配器管理系统连接器储存库30 ;连接器生成系统沈;与连接器生成系统沈和集成储存库30通信的储存库控制模块 22 ;与连接器生成系统沈进行通信的反馈模块M ;与要集成的一个或多个应用通信的连接器监视器观,其中,一个或多个应用适于使用连接器储存库30中的一个或多个连接器以促进一个或多个应用32与一个或多个其他应用的互连性;以及与储存库控制模块22、反馈模块24,以及连接器监视器模块观通信的一个或多个用户接口模块40、48、50、96。注意,连接器服务模块58可以包括适于使用一个或多个适配器创建连接器的机器可读指令,其中,与连接器相关联的功能是通过Web服务实现的。中间件18可以通过面向服务体系结构(SOA)服务器来实现,其中,SOA服务器托管中间件18。下面将参考图3的示例进程流更加全面地讨论系统10的示例操作。图3是表征图1-2的系统10的示例进程流110的流程图。进程流110被分成对应于用户动作182、连接器储存库动作184、连接器生成动作186、连接器反馈动作188,以及连接器监视器动作190的五个部分182-190。参考图2和3,一般而言,用户动作182对应于用户有选择地激活连接器储存库用户接口模块40的功能、连接器反馈用户接口模块48的功能,以及连接器监视器用户接口模块50的功能。示例进程流110开始,此时在初始集成对象步骤112输入集成对象。在本实施例中,集成对象是由用户输入的。然而,在某些实现方式中,可以响应于检测到事件,如由图1 的套件14的BES 76自动地输入集成对象。为了当前的讨论,集成对象可以是诸如类、JavaBean之类的任何编程语言结构,或封装影响第一App应用与第二App应用的交互的数据和/或功能的其他结构。一般而言, 集成对象可以用来封装其他集成对象,并可以包括与其相关联的各种命令或功能(也叫做"方法")和参数。集成对象可以对应于特定连接器。在输入集成对象或其描述之后,如通过图2的连接器储存库用户接口模块40进行输入,储存库控制模块22使用已输入的集成对象信息来获取与对象相关联的集成流。流可以在图3的集成流获取步骤114从图2的集成储存库30或连接器储存库元数据模块46获取。如果在随后的流检查步骤116中没有找到对应于集成对象的流,那么,获取所有相关联的触发事件。否则,如果流存在并被发现,那么,用户在流浏览步骤118浏览集成流 (例如,通过图2的连接器储存库用户接口模块40)。如果用户对集成流表示满意,如在满意度检查步骤120中所确定的,则在集成服务获取步骤136中检索相关联的集成服务以及其序列。如果用户对集成流不满意或没有发现集成流,则在触发事件获取步骤122获取所有触发事件。在通过图2的连接器储存库控制模块22获取触发事件之后,用户在触发选择步骤 124中选择事件触发。随后的命令获取步骤1 包括基于事件和相关联的集成对象获取该事件触发的命令。随后的命令检查步骤1 涉及检查在命令获取步骤126中是否成功地获取了命令。如果没有找到命令或命令不存在,那么,在元数据存储步骤132中存储涉及集成对象的元数据。另外,在可选的手动编码步骤134中,用户输入与已输入的集成对象相关联的连接器的任何所希翼的SQL代码和伴随的参数。在用户在手动编码步骤134中输入了任何所希翼的SQL代码和参数之后,描述SQL代码的任何额外的元数据都通过元数据存储步骤132 被存储。在完成元数据存储步骤132之后,进程流返回到满意度检查步骤120。如果用户不满意,则重复步骤122-134。否则,实行集成服务获取步骤136,接下来是服务存在检查骤138。如果如在服务存在检查步骤138中所验证的,图2的储存库控制模块22能够成功地获取集成服务和与已输入的集成对象相关联的命令序列,则实行集成服务浏览步骤140。 否则,激活图2的连接器生成系统沈,用于实行对应的一组连接器生成动作186。如果用于实现所希翼的连接器的服务不存在,则在生成器启动步骤158启动图2 的代码生成器56。随后,在元数据获取步骤160获取任何现有的连接器元数据。如果已获取的连接器元数据包括命令,如在命令检查步骤162中所验证的,那么,在适配器生成器启动步骤164启动适配器生成器。适配器生成器启动步骤164涉及启动连接器代码生成器56 的用于生成适配器的部分和连接器服务模块58的用于将适配器和连接器转换为服务的部分。随后,实行生产者生成步骤166,从而,生成生产者适配器以供作为服务公开。例如,生产者适配器可以包括用于将从生产者应用输入的和向其输出的消息从一般性消息转换为生产者应用所使用的特定消息并实行相反的操作的适配器。在比如通过图2的生产者BPEL模块68,以及通过诸如图2的中间件18之类的中间件,作为服务生成和实现适当的生产者适配器之后,则适当的适配器与特定生产者应用链接在一起,从而形成连接器。在生产者适配器链接步骤168中实行的链接可包括将为生产者生成的适配器与由图2的生产者BPEL 68所生成的其他链接的适配器进行链接,并且然后将由中间件所提供的链接适配器与由图2的生产者BPEL68所生成的其他链接的适配器进行链接。随后,实行消费者生成步骤170。在生产者适配器和任何中间件生成的适配器在生产者适配器链接步骤168中被链接之后,或在命令检查步骤162确定要生成的连接器缺乏命令之后,实现消费者生成步骤170。消费者生成步骤170比如通过图2的消费者ESB模块 70,包括生成连接器适配器并作为服务公布该适配器。随后,在变换映射获取步骤172,检索任何数据变换映射。变换映射包括用于将数据从一个应用传输到可使用不同类型消息的另一个应用的指令。然后,在变换服务生成步骤174,将已获取的变换映射转换为服务。变换服务生成步骤174可以使用图2的变换BPEL 模块72来促进将变换映射转换为变换服务。随后,实行服务链接步骤176,从而,所有生成的服务被适当地链接在连接器服务中。随后,元数据存储步骤178包括存储与链接的服务相关联的元数据以及伴随的连接器。比如在图1的集成适配器管理系统12的元数据储存库46中存储的连接器元数据信息,可以周期性地或自动地与集成储存库30中存储的相应元数据或存储在别处的元数据同步。在用户动作182的集成服务浏览步骤140中,用户可以决定浏览连接器运行时信息,从而有选择地激活连接器监视动作190。在此情况下,从诸如图2的数据库16的数据库中检索涉及与所希翼的连接器相关联的集成对象的运行时信息。另外,还从诸如图2的中间件18的中间件检索与和该连接器相关联的任何服务相关联的任何运行时信息。在随后的信息分组步骤156中,根据与连接器相关联的对象的名称以及规定何时运行连接器服务和相关联的对象的任何时间戳,将检索到的运行时信息分组供使用。然后,由用户在运行时查看步骤192中查看分组后的运行时信息。在用户动作182的集成服务浏览步骤140中,用户可以决定浏览连接器反馈信息和/或提供连接器反馈信息。在此情况下,实行反馈获取步骤142。反馈获取步骤142涉及
14从图2的反馈日志92检索或访问反馈信息,以供连接器反馈用户接口模块48使用。应注意,在本实施例中,由用户实行或启动利用用户动作182分组的各个步骤。然而,这样的步骤中的一个或多个步骤可以由诸如在套件14上运行的App和/或图2的集成适配器管理系统12之类的App自动地实行,而不会偏离本公开的范围。随后,可以实行可选的反馈查看步骤144。反馈查看步骤144包括查看在前面的反馈获取步骤142中检索到的反馈的内容。接下来,可以实行可选的反馈输入步骤146。反馈输入步骤146包括输入特定连接器、适配器和/或伴随的服务的评定。接下来,反馈存储步骤148包括在图2的服务反馈日志92中存储输入的反馈信息。图2的反馈日志92可选地与伴随的企业中的一个或多个实体,比如运行图2的套件14的中心企业应用服务器或其他服务器,同步。图4描绘了表征图1-2的系统10的连接器进程流210和相关联的命令212、参数 214、服务216,以及反馈过程218之间的示例关系200的示例实体关系(ER)图。参考图2和图4,给定流210,如在图2的集成储存库30和元数据储存库46中维护的,可以包括可以与多个命令212相关联的多个连接器和适配器。每一命令212都可以具有多个命令参数214。图2的连接器生成系统沈可以为每一个流210和伴随的命令212 创建一个或多个服务。图2的反馈模块M促进接收诸如连接器服务评定之类的用户反馈, 其中每个连接器服务,也叫做流服务,可以与用户反馈218的多个实例相关联。在下表中指定了几个示例流表 1(流)
权利要求
1.一种用于管理用于集成App应用的集成适配器的方法,所述方法包括检测连接器在连接器的储存库中不可用的事件;以及响应于检测到所述事件,生成一个或多个连接器。
2.如权利要求1所述的方法,进一步包括监视与连接器相关联的运行时信息,并存储所述运行时信息作为响应。
3.如权利要求2所述的方法,进一步包括维护涉及连接器的储存库中的一个或多个连接器的操作的反馈信息。
4.如权利要求3所述的方法,进一步包括提供一个或多个接口以促进使用户能够提供涉及连接器的反馈和查看运行时信息。
5.如权利要求4所述的方法,进一步包括提供搜索引擎以促进使用户能够使用一个或多个用户接口以在连接器的储存库中搜索所希翼的连接器。
6.如权利要求4所述的方法,进一步包括检测连接器储存库中的定制或扩展的适配器,并作为响应向一个或多个用户接口模块提供指示。
7.如权利要求3所述的方法,进一步包括将一个或多个所生成的连接器实现为Web服务。
8.如权利要求7所述的方法,其中,所述实现还包括根据甲骨文企业的应用集成体系结构集成框架来实现所述一个或多个所生成的连接器。
9.如权利要求1所述的方法,进一步包括检测由一个或多个所述App应用所触发的事件,并提供信号作为响应。
10.如权利要求9所述的方法,进一步包括提供适于促进实现与检测到的事件相关联的进程的连接器。
11.如权利要求10所述的方法,其中,提供连接器还包括使用连接器服务模块,所述连接器服务模块与连接器代码生成器进行通信以促进提供所述连接器。
12.如权利要求11所述的方法,其中,所述连接器服务模块包括事件适配器。
13.如权利要求1所述的方法,进一步包括在第一应用所使用的第一特定消息类型和一般性消息类型之间进行转换;在所述一般性消息类型和第二App应用所使用的第二特定消息类型之间进行变换;确定何时用于实行转换的特定类型的连接器是所述转换步骤或变换步骤所要求的,但是所述特定类型的连接器不可用,并提供第一信号作为响应;以及响应于所述第一信号,选择性地生成供所述转换步骤或变换步骤使用的连接器。
14.如权利要求13所述的方法,进一步包括收集和存储涉及所述转换步骤或变换步骤所使用的给定连接器的性能的反馈。
15.如权利要求13所述的方法,进一步包括搜索连接器储存库以寻找所述转换步骤或变换步骤所要求的连接器。
16.如权利要求15所述的方法,进一步包括引用涉及所述连接器储存库中的一个连接器的反馈数据,以促进确定供所述转换步骤或变换步骤使用的连接器。
17.如权利要求13所述的方法,进一步包括促进监视与所述转换步骤或变换步骤所使用的连接器的运行相关联的运行时信息。
18.如权利要求1所述的方法,进一步包括使用连接器的储存库、连接器生成系统、与所述连接器生成系统和所述连接器的储存库进行通信的储存库控制模块、与所述连接器生成系统进行通信的反馈模块、与要集成的一个或多个应用进行通信的连接器监视器,以及与所述储存库控制模块、反馈模块,以及所述连接器监视器模块进行通信的一个或多个用户接口模块以促进实现所述检测步骤和生成步骤。
19.一种用于管理用于集成App应用的集成适配器的设备,所述设备包括用于检测连接器在连接器的储存库中不可用的事件的装置;以及用于响应于检测到所述事件,生成一个或多个连接器的装置。
20.如权利要求19所述的设备,进一步包括用于监视与连接器相关联的运行时信息, 并存储所述运行时信息作为响应的装置。
21.如权利要求20所述的设备,进一步包括用于维护涉及连接器的储存库中的一个或多个连接器的操作的反馈信息的装置。
22.如权利要求21所述的设备,进一步包括用于提供一个或多个接口以促进使用户能够提供涉及连接器的反馈和查看运行时信息的装置。
23.如权利要求22所述的设备,进一步包括用于提供搜索引擎以促进使用户能够使用一个或多个用户接口以在连接器的储存库中搜索所希翼的连接器的装置。
24.如权利要求22所述的设备,进一步包括用于检测连接器的储存库中的定制或扩展的适配器,并作为响应向一个或多个用户接口模块提供指示的装置。
25.如权利要求21所述的设备,进一步包括用于将一个或多个所生成的连接器实现为 Web服务的装置。
26.如权利要求25所述的设备,其中,所述用于将一个或多个所生成的连接器实现为 Web服务的装置还包括用于根据甲骨文企业的应用集成体系结构集成框架来实现所述一个或多个所生成的连接器的装置。
27.如权利要求19所述的设备,进一步包括用于检测由一个或多个所述App应用所触发的事件,并提供信号作为响应的装置。
28.如权利要求27所述的设备,进一步包括用于提供适于促进实现与检测到的事件相关联的进程的连接器的装置。
29.如权利要求观所述的设备,其中,所述用于提供连接器的装置使用连接器服务模块,所述连接器服务模块与连接器代码生成器进行通信以促进提供所述连接器。
30.如权利要求四所述的设备,其中,所述连接器服务模块包括事件适配器。
31.如权利要求19所述的设备,进一步包括用于在第一应用所使用的第一特定消息类型和一般性消息类型之间进行转换的装置;用于在所述一般性消息类型和第二App应用所使用的第二特定消息类型之间进行变换的装置;用于确定何时用于实行转换的特定类型的连接器是所述用于进行转换的装置或用于进行变换的装置所要求的,但是所述特定类型的连接器不可用,并提供第一信号作为响应的装置;以及用于响应于所述第一信号,选择性地生成供所述用于进行转换的装置或用于进行变换的装置使用的连接器的装置。
32.如权利要求31所述的设备,进一步包括用于收集和存储涉及所述用于进行转换的装置或用于进行变换的装置所使用的给定连接器的性能的反馈的装置。
33.如权利要求31所述的设备,进一步包括用于搜索连接器储存库以寻找所述用于进行转换的装置或用于进行变换的装置所要求的连接器的装置。
34.如权利要求33所述的设备,进一步包括用于引用涉及所述连接器储存库中的一个连接器的反馈数据,以促进确定供所述用于进行转换的装置或用于进行变换的装置使用的连接器的装置。
35.如权利要求31所述的设备,进一步包括用于促进监视与所述用于进行转换的装置或用于进行变换的装置所使用的连接器的运行相关联的运行时信息的装置。
36.如权利要求19所述的设备,进一步包括连接器的储存库、连接器生成系统、与所述连接器生成系统和所述连接器的储存库进行通信的储存库控制模块、与所述连接器生成系统进行通信的反馈模块、与要集成的一个或多个应用进行通信的连接器监视器,以及与所述储存库控制模块、反馈模块,以及所述连接器监视器进行通信的一个或多个用户接口模块。
全文摘要
一种集成适配器管理系统(IAMS)。在一个示例实施例中,该系统管理用于集成App应用的适配器和连接器。示例系统包括连接器储存库,其中,每个连接器都包括一个或多个集成适配器。连接器生成器与连接器储存库进行通信,并适于响应于检测到在连接器储存库中找不到对应的连接器的事件,有选择地生成一个或多个连接器。在更具体的示例实施例中,连接器生成器适于将一个或多个所生成的连接器实现为Web服务。连接器生成器可以根据Oracle的应用集成体系结构(AIA)集成框架来构建。提供了用于监视连接器运行时信息并接收和记录涉及连接器的用户反馈的额外的工具。
文档编号G06F9/46GK102346685SQ20101024762
公开日2012年2月8日 申请日期2010年7月29日 优先权日2010年7月29日
发明者S·卡玛特, 刘剑波, 李文华 申请人:甲骨文国际企业
再多了解一些
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1

威尼斯人棋牌|威尼斯欢乐娱人城

XML 地图 | Sitemap 地图