Oracle SOA Suit Medicator and OSB

Medicator和OSB (Oracle Service Bus)存在的目的,从架构的设计模式上看,和解耦多态等理念非常的相似。 通过Proxy代理的方式,把真正某个Service的实现进行隐藏,让依赖于Service的应用只依赖Service接口,而在接口后面 Routing过去的Service,可以更方便的维护和修改。专业的术语Loosely-Coupling Services.
Service解耦设计原则:
Service的输入参数,越少越好,只输入必要的参数。过多的参数,以及通用的参数只会让Service更加难以维护。比如Credit Rate的Service,比较好的参数就只限定在Individual信息,而其他比如交易的Amount, 货物的Type等就最好不加入到输入参数里面。
Service的输出参数,也是越少越好,不要过多的把不必要的内部数据暴露在外面。
减少Service之间的依赖关系。Service之间可以互相组合成新的Service,但是这个组合尽量不要有业务上的组合。
Service里面的实现不要引用Share Global Data
尽量加入asynchronous message来解耦dependency.  Request和Response不需要在同时完成是比较好的方法。
Service一般情况下不应该是有状态的,Client不应该依赖Service的状态而设计Functionality。 有状态的Service一般用在两种情况, 1是查询结果,返回的总数量多于每次获取的数量。2是Client和Service之间要有多次交互。 
对于有状态的Service的管理,比较好的实践就是把State Management移除到service外面,用Medicator或者是OSB来实现。 Client-->Facade(Session Mgmnt)-->Native StateMgmnt
Medicator和OSB的应用场景:
Medicator是Service Component的一部分,和OSB不同,OSB是另外一个独立的应用在Service Componet之外。
Medicator:
* 一个Service里面有多个Service Component的时候,采用Medicator进行Routing.
* 校验SCA的Message.  Service Component Assemblies.
* SCA内部数据类型,格式转换
* 通过Message Content来判断选择指定的Component
OSB:  相对SCA来说是独立的JVM
缺点是会有多余的响应时间, Client --> OSB --> SCA  vs Client -- > SCA
优点是让所有公司内部Service,或者外部的Non-SCA service,都统一Suite,方便使用和管理
由于Client Code不是直接引用到目标Service Code,所以在Runtime很方便进行维护
OSB作为一个Service入口可以调节Request的负载均衡,避免真正的Service突然被海量Request给挤垮
Oracle Service Bus的主要功能:
Message Flow:
invoker的message首先到达的是Proxy Server
然后进入到Input Pipeline, 进行Format, Validation, Logging, Enrich等操作。
之后进入到Routing Step,用来决定由哪个Business Service来执行这个Request
最后,被选中的Business Service调用真正的Service来响应。
Response的信息同样要经过Format, Logging, Enrich等操作才到达Invoker.
Service Endpoint Vitalization:
* 把真正的Service隐藏在Business Service后面 ,配置Business Service的Protocal,让invoker可以采用各种不同的Protocal访问真正Service
* 添加了负载均衡的策略
* 添加Retry的策略,超时策略等
Monitoring:
提供非常强大的功能为所有失败的响应生成Logging, Alert或者是Report.

时间: 2024-07-30 16:38:57

Oracle SOA Suit Medicator and OSB的相关文章

Oracle SOA Suit Adapter

SOA架构的一个核心的使命是整合企业现存的各式各样的计算资源,它不仅仅是代码层面的整合,更是硬件,计算能力,服务能力的整合.Oracle SOA Suite在这方面做得特别的贴切,它提供了一组Adapter的组件用来包装现存的资源. 现存资源被使用的情景一般都能涵括在如下的一些方式: * 文件交互方式,外界往相应的目录传入一个文件,系统扫描目录,获取文件指令,计算完毕后,向指定目录生成新的文件. * 数据库访问方式,暴露一个存储过程,或者是一个Interface Table, 外界写入数据,然后

Oracle SOA套件12c

产品概览 随着基于云的应用越来越多的被企业所採用,以及移动技术与企业应用的集成的需求的增多,企业级应用集成的复杂度也前所未有的提升. Oracle SOA套件12c,业内最完整的统一应用集成解决方式的最新版本号,帮助用户应对这一挑战. Oracle SOA套件12c在单一的平台之上提供了与云.移动.企业内部应用和物联网进行集成的能力,帮助用户用最快的时间实现集成,提高生产效率.减少总体拥有成本. Oracle SOA套件是一个全面的,基于标准的软件套件,用于根据SOA架构的概念进行集成应用的创建

Fusion_基于Oracle SOA的企业服务总线整合

2015-01-01 Created By 鲍新建 一.方案背景 随着企业信息化程度的不断提高,企业IT系统日趋庞大,跨系统流程以及各个系统之间.以及系统内部的接口需求和接口服务调用也不断增加. 目前,由于相互系统间的接口调用过多.且缺乏一个统一的管理规范,导致目前接口协议种类过多,各个系统之间的接口呈网状结构. 为适应企业战略发展的要求,结合企业信息化项目建设方案, 以面向服务的体系架构(Service Oriented Architecture,简称SOA)思想为指导进行系统集成是为了从业务

SOA_搭建和安装Oracle SOA Suite11g(案例)

2015-01-01 Created By BaoXinjian 一.摘要 本文档介绍soa相关软件的安装和配置,以及安装过程中的注意事项. 安装过程需要按照quickstartguidesoasuite这个文档进行,需要注意一下几点: 1. 由于安装的软件较多,为了以后维护方便,尽量提前做好目录规划,并在安装过程中选择所规划好的oracle主目录. 2. 软件版本需要匹配,根据安装指南中指定的版本下载软件,否则安装过程中会提示软件版本不匹配. 3. 只安装自己需要的组件,根据安装指南中介绍的组

Oracle SOA Suite OverView

SOA是一场架构的变革,那既然是变革,那就一定是有内在的原因来推动这个架构的变革.在过去几十年的时间里面,应用程序架构已经经历了3次巨大的变革,从Terminal/主机--> Client/Server-->Browser/Server, 无一例外,程序的复杂度,需求易变性,资源重用的等,都是不断推动架构变革的内在动力.而到如今,随着协同工作,企业资源管理等需求,单一的产品已经很难满足客户多样的需求,如何最大限度的集成多样化的产品,减少成本成为最迫切的需求.SOA就是在这样的内因下才广为人知.

Windows 7/Vista下安装Oracle Developer Suit遇到的几个问题

http://blog.csdn.net/pan_tian/article/details/8016318 Oracle Developer Suite (ODS) 10g是在Windows 7/Vista之前开发出来的,在Win7/Vista下安装的过程中一些的问题,常见的问题及解决方法如下:   问题1:Checking operating system version: must be 5.0, 5.1 or 5.2.    Actual 6.1 Win7/Vista下安装Form Bui

Dblink接口向Oracle Soa Suite迁移,实现数据复制和日志功能

1.主体设计 Dblink向soa-suite迁移的前提是,Dblink双方都有独立的接口表,迁移后的效果是,由一个Mediator触发事件,此事件触发后,由BPEL部件来捕获这个事件,在这个BPEL部件内部,通过DbAdapter(日志部件,读部件,写部件)的协作来完成日志记录,数据读取 ,数据转换 ,数据写入的Dblink功能实现. 2.组件规划 Mediater触发事件 BPEL完成Dblink数据复制过程 DbAdapter完成基于数据库的日志写(Db_Log),数据读(Db_Read)

Oracle Fusion Middleware 基础知识总结

1, Oracle Fusion Middleware 产品 1.1 集成开发环境 (IDE): Oracle JDeveloper, Oracle Enterprise Pack for Eclipse 1.2 应用开发框架: Application Development Framework (ADF) 1.3 应用网格: WebLogic Server 1.4 身份管理: 目录服务,访问管理,身份联合,欺诈检测, 权利服务,身份管理,身份分析 1.5 面向服务的构架 (SOA): Orac

Oracle 数据集成的实际解决方案

就针对市场与企业的发展的需求,Oracle公司提供了一个相对统一的关于企业级的实时数据解决方案,即Oracle数据集成的解决方案.以下的文章主要是对其解决方案的具体描述,望你会有所收获. Oracle 数据集成解决方案 Oracle数据集成解决方案用于在SOA.BI和数据仓库环境中构建.部署和管理以实时数据为中心的架构,包含了Oracle数据集成的所有要素--实时数据移动.转换.同步.数据质量.数据管理和数据服务--能确保各个复杂系统的信息及时.准确.一致. 通过使用Oracle数据集成,企业将