如果您正计划将现有的中间件转换为面向服务的体系结构(SOA)平台,那么可以考虑使用 Apache Synapse。这是一种替代专有企业服务总线(ESB)的、易于使用的、开放源代码产品,其成本更低并且所需进行的工作更少。本文向您全面地介绍了 Apache Synapse,并提供了一个用例,以说明如何使用 SOA 方法集成并重用现有的应用程序。
Apache Synapse 的概述
Synapse 是一个简单的 XML 和 Web 服务管理与集成代理,可用于构成 SOA 和企业服务总线(ESB)的基础。Synapse 最近刚刚由 Apache 孵化器“孵化”完成,现在是 Web 服务项目中一项成熟的 Apache 活动,并且是非常成功的 Apache Axis2 项目的一个分支。它提供了中介、管理、以及在各种不同的应用程序之间转换 XML 消息的能力。
大多数公司热衷于将它们现有的中间件转换为 SOA 平台,通常这需要花费很大的代价。Apache Synapse 是一个简单的、高质量开放源代码的替代方法,为实现 SOA 提供了一种途径,它可以公开现有的应用程序,而无需重新编写任何代码。重用、集成、管理和控制 与现有应用程序的交互,而无需对它们进行更改,这种能力使得 Synapse 成为一项颇具吸引力的选择、以及实现 SOA 策略的关键途径。
不幸地是,ESB 概念定义得非常糟糕。然而,我们提供了一个简单的、实际的定义:连接、转换、管理。
ESB 模型促进了与服务契约和与服务契约相关联的元数据的基于 SOA 的集成,如 Web 服务描述语言(WSDL)、模式或策略。ESB 模型(请参见图 1)确保进入该总线的每条消息最终都能到达正确的位置。
勿庸置疑,目前 XML 已经成为通用数据格式,受到几乎所有编程语言的广泛认可和支持。这使得异类应用程序能够使用共同的数据模型来传递数据,而任何语言都可以很容易理解这个数据模型。在 Synapse 中,所有的内容都是与 XML 有关的,并且其思想是在网络中尽可能地使用 XML,从而将您的整个网络变为一个总线。这样做的原因之一是,网络中所有的 XML 交互构成了 ESB,可以使用 Synapse 对这个总线进行管理(请参见图 2)。
下面的案例研究说明了如何使用 SOA 方法集成和重用现有的应用程序,以便处理信用卡支付系统的中间件操作。
需求
ABC 银行已经决定提供一个基于 Internet 的支付网关。该应用程序需要接受在线信用卡支付请求,检查欺诈行为,然后使用 Visa 或者 MasterCard 系统对请求进行验证。这个银行拥有一些现有的应用程序,包括检测欺诈性交易的应用程序、审核系统、短消息服务(SMS)应用程序、以及用于信用卡处理的 Visa 和 MasterCard 应用程序。
解决方案
您可以使用 Synapse 集成、管理、控制这些现有的应用程序,并使用 SOA 方法将这些现有的应用程序转换为服务。使用基于脚本的中介(允许重用现有的应用程序,而无需重写代码)可以完成一些简单的逻辑,比如防止欺诈的初始审查、基于内容的路由、以及欺诈评分处理。如果这些脚本来自于动态注册中心,那么它可以提供修改相关逻辑而无需重新启动Synapse、以及干扰交易的灵活性。
体系结构
正如图 5 中的图表所示,首先使用脚本中介对请求进行审查,防止欺诈交易的可能性。如果它是可信的,使用切换中介将它发送到 Visa 或者 MasterCard 服务,到底是哪个服务依赖于银行卡的类型。如果欺诈审查流程确定需要将该交易发送到欺诈评分系统,那么将其转发到欺诈评分服务。欺诈评分服务为这个交易分配一个欺诈分值。然后,欺诈警报服务使用切换中介来确定活动过程,以便根据欺诈分值来定义相应的传输逻辑路径。
图 5. 体系结构图表
总结
Synapse 提供了一个简单的、易于使用的、开放源代码替代方法,以最少的成本和工作量,将您现有的中间件重新构造为 SOA 平台。通过中介或者转换现有的服务,而无需进行编码,Synapse 实现了重用的最大化,并且提供了一种优秀的模型,以便将您的服务集成到 ESB 模型。