- 浏览: 3513486 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
-
wanglf1207:
EJB的确是个不错的产品,只是因为用起来有点门槛,招来太多人吐 ...
weblogic-ejb-jar.xml的元素解析 -
qwfys200:
总结的不错。
Spring Web Flow 2.0 入门 -
u011577913:
u011577913 写道也能给我发一份翻译文档? 邮件437 ...
Hazelcast 参考文档-4 -
u011577913:
也能给我发一份翻译文档?
Hazelcast 参考文档-4 -
songzj001:
DbUnit入门实战
2007 年 9 月 06 日
如果您正计划将现有的中间件转换为面向服务的体系结构(SOA)平台,那么可 以考虑使用 Apache Synapse。这是一种替代专有企业服务总线(ESB)的、易于使用的、开放源代码产品,其成本更低并且所需进行的工作更少。本文向您全面地介绍了 Apache Synapse,并提供了一个用例,以说明如何使用 SOA 方法集成并重用现有的应用程序。<!-- START RESERVED FOR FUTURE USE INCLUDE FILES--><!-- include java script once we verify teams wants to use this and it will work on dbcs and cyrillic characters --> <!-- END RESERVED FOR FUTURE USE INCLUDE FILES-->
Synapse 是一个简单的 XML 和 Web 服务管理与集成代理,可用于构成 SOA 和企业服务总线(ESB)的基础。Synapse 最近刚刚由 Apache 孵化器“孵化”完成,现在是 Web 服务项目中一项成熟的 Apache 活动,并且是非常成功的 Apache Axis2 项目的一个分支。它提供了中介、管理、以及在各种不同的应用程序之间转换 XML 消息的能力。
Apache Synapse 项目最近发行了版本 1.0。您可以在 Apache Synapse 网站(请参见参考资料 中提供的链接)上阅读更多关于这个重要的发行版的信息。
大多数公司热衷于将它们现有的中间件转换为 SOA 平台,通常这需要花费很大的代价。Apache Synapse 是一个简单的、高质量开放源代码的替代方法,为实现 SOA 提供了一种途径,它可以公开现有的应用程序,而无需重新编写任何代码。重用、集成、管理和控制 与现有应用程序的交互,而无需对它们进行更改,这种能力使得 Synapse 成为一项颇具吸引力的选择、以及实现 SOA 策略的关键途径。
不幸地是,ESB 概念定义得非常糟糕。然而,我们提供了一个简单的、实际的定义:连接、转换、管理 。
ESB 模型促进了与服务契约和与服务契约相关联的元数据的基于 SOA 的集成,如 Web 服务描述语言(WSDL)、模式或策略。ESB 模型(请参见图 1)确保进入该总线的每条消息最终都能到达正确的位置。
![]() ![]() |
![]()
|
让我们来看看构建 Synapse 的原则。
Synapse 构建于 XML 和 Web 服务标准之上。从最基础的角度而言,Synapse 建立在通过网络传送消息的思想之上。消息可以采用任何格式,但是 Synapse 将它们放到一个逻辑信息集(请参见参考资料 以 获取更详细的信息)中,并采用包含 Header 和正文的信封的 SOAP 方法对其进行建模。通过使用 Web 服务标准,如 WS-ReliableMessaging 和 WS-Security,您可以使用 Synapse 以确保应用程序之间安全的、可靠的连接。Synapse 可以负责这些类型的服务质量(QoS)功能,而无需修改现有的应用程序。例如,通过在现有的 XML/HTTP 服务前面直接放置一个 Synapse 实例,您就可以添加对 WS-Security 的支持。这样可以添加对数字签名的支持,在 B2B 环境中是很重要的。
随 着 Web 的出现,HTTP 已经成为通用的信息传输方法。由于它具有防火墙友好性、广泛的可用性、得到广泛的承认、以及 HTTP 在全球范围内受到广泛支持,大多数企业已经使用 HTTP 公开他们的服务。可以以两种不同的方式 — 来看待 HTTP,将其视为实际的交互协议,或视为传输协议。那些将 HTTP 视为交互协议的人将遵循 REST(请参见参考资料 以获取更详细的信息)模型,并且倾向于严格遵守 HTTP 动词(GET、PUT、POST、DELE)语义。还可以将 HTTP 作为防火墙友好的传输方式,在这种情况下,通常的模型是发送 XML 文档,然后再从响应中获取 XML 文档。
SOAP 是一种通用的、传输方法独立的消息传递格式。因为它与平台、传输方法和语言无关的本质,所以它已被许多应用程序所采用,从帮助 eBay PowerSellers 管理他们的店铺,到跨网络发送打印作业。它也是许多高层次规范的基础。它可以与其他机制一起使用或者单独使用,实际上,SOAP 和 HTTP 构成了通用的交互模型,并且可以连接企业边界内外的异类系统。
尽管 Synapse 支持许多不同的传输方式,包括 Java™ 消息服务(JMS)、邮件、XML/HTTP 和 SOAP,其核心仍然使用了 SOAP 模型。这意味着什么呢?从最基础的角度而言,这意味着有反映 SOAP 信封的内部数据结构。例如,to 和 replyTo 地址使用 WS-Addressing 规范进行建模。当消息流通过 Synapse 引擎时,可以使用标准中介将消息与各种格式之间进行转换,包括 REST、SOAP、JavaScript Object Notation (JSON) 和 JMS。此外,可以通过编写自定义中介对其进行扩展。
勿 庸置疑,目前 XML 已经成为通用数据格式,受到几乎所有编程语言的广泛认可和支持。这使得异类应用程序能够使用共同的数据模型来传递数据,而任何语言都可以很容易理解这个数 据模型。在 Synapse 中,所有的内容都是与 XML 有关的,并且其思想是在网络中尽可能地使用 XML,从而将您的整个网络变为一个总线。这样做的原因之一是,网络中所有的 XML 交互构成了 ESB,可以使用 Synapse 对这个总线进行管理(请参见图 2)。
![]() ![]() |
![]()
|
可以使用不同的方法来部署 Synapse。部署 Synapse 的最简单的方法是使用代理 概念。
在 代理模型(如图 3 所示)中,您明确地定义一个新的端点(代理),Synapse 在该端点上进行侦听。实际上,这就像一个新的服务,除了服务逻辑是通过远程服务来实现之外。在这个模型的最简单的实例化过程中,您可以直接将代理侦听器连 接到远程端点。然而,即使在这种简单的情况下,您也可以完成一些有价值的事情。例如,您可以在 XML/HTTP、SOAP 以及 JMS 之间进行切换。您可以打开或者关闭某些协议,如 WS-Addressing、WS-ReliableMessaging 和 WS-Security。并且在 Synapse 1.0 发行版中,您可以在这些协议之间定义一组相同的服务并平衡负载。
在 这一方法中,您可以对客户端进行配置,以便将所有的消息发送到 Synapse。例如,Synapse 可以作为一个 HTTP 代理。这是非常方便的,因为几乎每个 Web 客户端都可以配置 HTTP 代理,而无需改变应用程序代码。所以,通常只需要对通过 Synapse 的消息进行重定向即可。Synapse 有一个缺省的活动序列,应用于按这种方式到达的任何消息。然后,可以使用诸如基于内容的筛选(XPath 或者 Regex)之类的技术,以便有选择地将这些策略应用于特定的消息。
![]() ![]() |
![]()
|
Apache Synapse 实现了通用的中介框架。如前所述,您可以指定一个对消息进行操作(基于它所到达的端点、或基于某种筛选)的中介序列 。Synapse 的目标是支持一组有价值的、即时可用的中介。这类内置中介包括:
- 记录日志到 log4j。
- 修改 Header,包括 WS-Addressing Header。
- 运 行脚本,包括 JavaScript、Groovy、Ruby 和 Bean Scripting Framework (BSF) 所支持的其他脚本。E4X 支持允许 JavaScript 直接操纵 XML 消息,而不需要使用像 DOM 这样的 API。在 Ruby 中也存在类似的支持。
- 启用和终止 WS-Security 与 WS-ReliableMessaging。
- 在 SOAP 版本和 XML/HTTP 之间进行切换。
- XML 模式验证。
- 发现消息中的错误或者丢弃它们。
![]() ![]() |
![]()
|
正如前几部分中所介绍的,Synapse 可以连接和管理您的服务,并为您的服务提供中介。
除 了在内部网中进行操作之外,Synapse 还可以用作您企业的网关,并且更有效地管理对合作伙伴公开的服务。网关模型可以包括使用 Apache Rampart 框架应用身份验证机制、以及对进入的消息进行授权,以支持 WS-Security 和 WS-SecureConversation。通过将网络内部的虚拟 URL 映射为真实 URL,Synapse 可以使得您的企业能够在隐藏内部基础结构细节的同时,为外部系统维护统一的寻址方案。您可以在组织内部使用相同的模型,以便独立于具体的实现,提供一套清 晰的、可管理的总线级别服务。集中式的连接模型也促进了对 QoS 各个方面的更好管理。
例如,可以使用 Synapse 将简单的 GET HTTP 请求映射为与后端连接的 XML/JMS。使用这种方法,可以对更大范围的客户端公开遗留的资源,包括 Asynchronous JavaScript + XML (Ajax) 应用程序和移动设备。
Synapse 为管理策略和服务的其他方面提供了一致的模型。通过将 Synapse 作为中间层,您可以控制诸如身份验证、审核、日志之类的方面,或者诸如故障转移和负载平衡之类的 QoS 方面。这使得您的组织可以更高效且更有效地管理资源。可以通过配置一个简单的 XML 文件来启用所有这些特性,而无需编写任何代码。
下面提供了一些示例:
- 可以将 http://stockquote.com?symbol=RHAT 映射为一个服务,并作为一个基于负载平衡策略(如 Round Robin)的集群进行部署。如果是主服务器加后备服务器的情况,当主服务器关闭时,故障转移中介可以将它映射到后备服务器。
- 可以为所有的对 http://abcbank.com/personal 的请求进行身份验证、日志记录、以及随机地进行日志记录和审核标注。
- 可 以对 http://abcbooks.com/suppliers?category=XXXX 应用中介,以便根据供应商类别添加不同的策略。例如,如果 category=silver,那么供应商的信用额度是 5000;如果 category=gold,那么供应商的信用额度可以是 10000。
Synapse 可以将您的遗留应用程序转换为先进的 Web 服务。Synapse 可以用作代理,并且可以通过完成下面的一项或者多项工作实现服务和应用程序的虚拟化:
- 对 SOAP 消息(Header 或正文)执行 XSL 转换(XSLT)
- 使用 JavaScript/E4X 转换程序直接将 XML 映射为 JavaScript
- 使用传统的 Java 对象(POJO),您可以在其中编写 Java 逻辑,以便对消息进行操作
- 将 JSON 映射为 XML,其中可以将 JSON/HTTP 流作为 SOAP 消息发送,反之亦然
- 执行附件中介,其中可以将带附件的 SOAP 转换为 Message Transmission Optimization Mechanism (MTOM)、将 Base64 转换为 MTOM,反之亦然。
- 执行您自己的自定义转换
这为重用您现有的应用程序、以最少的投资对它们进行集成以提供更好的服务提供了机会。有了 Synapse,您可以将整个网络转换为 ESB,这个 ESB 提供了集中式和一致的方法,以便管理所提供的服务。
![]() ![]() |
![]()
|
下面的案例研究说明了如何使用 SOA 方法集成和重用现有的应用程序,以便处理信用卡支付系统的中间件操作。
ABC 银行已经决定提供一个基于 Internet 的支付网关。该应用程序需要接受在线信用卡支付请求,检查欺诈行为,然后使用 Visa 或者 MasterCard 系统对请求进行验证。这个银行拥有一些现有的应用程序,包括检测欺诈性交易的应用程序、审核系统、短消息服务(SMS)应用程序、以及用于信用卡处理的 Visa 和 MasterCard 应用程序。
您 可以使用 Synapse 集成、管理、控制这些现有的应用程序,并使用 SOA 方法将这些现有的应用程序转换为服务。使用基于脚本的中介(允许重用现有的应用程序,而无需重写代码)可以完成一些简单的逻辑,比如防止欺诈的初始审查、 基于内容的路由、以及欺诈评分处理。如果这些脚本来自于动态注册中心,那么它可以提供修改相关逻辑而无需重新启动Synapse、以及干扰交易的灵活性。
正 如图 5 中的图表所示,首先使用脚本中介对请求进行审查,防止欺诈交易的可能性。如果它是可信的,使用切换中介将它发送到 Visa 或者 MasterCard 服务,到底是哪个服务依赖于银行卡的类型。如果欺诈审查流程确定需要将该交易发送到欺诈评分系统,那么将其转发到欺诈评分服务。欺诈评分服务为这个交易分 配一个欺诈分值。然后,欺诈警报服务使用切换中介来确定活动过程,以便根据欺诈分值来定义相应的传输逻辑路径。
如前所述,配置这个逻辑就像编写一个 XML 文件那样简单。然而,详细地描述代码示例已经超出了本文的范围。我提供了代码示例附件(请参见 参考资料 以获取 synapse.xml 的链接)以说明其易用性,并且大多数代码都是自我说明的,如果您遵循图 5 中的图表。您可以使用参考资料 部分中提供的链接,下载完整的 synapse.xml 文件。
![]() ![]() |
![]() |
Synapse 提供了一个简单的、易于使用的、开放源代码替代方法,以最少的成本和工作量,将您现有的中间件重新构造为 SOA 平台。通过中介或者转换现有的服务,而无需进行编码,Synapse 实现了重用的最大化,并且提供了一种优秀的模型,以便将您的服务集成到 ESB 模型。
发表评论
-
说明SOA监管(SOA Governance)实例(收录备查)
2012-12-19 11:35 1766SOA 已经不是单纯技术问 ... -
Injecting Spring Beans into Java Servlets
2012-11-01 10:21 1950If you are working in a Java ... -
用 HttpServletResponseWrapper 实现 Etag 过滤器
2012-07-09 16:58 3778原文出处:http://blog.chenlb.com/200 ... -
Eclipse Indigo - Cannot install Android ADT Plugin
2012-02-29 01:17 3896When I try to install the And ... -
Eclipse Indigo - Cannot install Android ADT Plugin
2012-02-29 01:13 2011When I try to install the And ... -
[转]mybatis下的分页,支持所有的数据库
2011-07-21 13:21 14856大 家都知道,mybatis的自带分页方法只是逻 ... -
Java framework for text- & console-based forms?
2011-07-21 01:06 1731charva jcurses JNA , ... -
JNA(Java Native Access)学习入门
2011-07-21 01:04 22692Java Native Access 项目 在 ... -
使用IntrospectorCleanupListener 解决quartz引起的内存泄漏
2011-04-20 11:59 13407"在服务器运行过程中,Spring不停的运行的计划任 ... -
DBCP代码研读以及就数据库连接失效的解决
2011-03-31 11:03 3782问题 网上很多评论说DBCP有很多BUG,但是都没有指明是什 ... -
ContextLoaderListener
2010-12-06 15:58 8478(1) org.springframework.web.c ... -
Servlet3.0新功能: 异步处理
2010-12-06 15:22 3205J2EE 6和Glassfish 3V正式发 ... -
Servlet3.0引入的新特性
2010-12-06 15:20 3070Servlet3.0规范的新特性主要是为了3个目的: ... -
100個節點上運行群集亞馬遜EC2上Hazelcast
2010-12-03 23:59 3333本文的目的,適是给妳湮示的細節集群的100個節點。此湮示記錄, ... -
Spring Properties Reloaded
2010-12-02 14:54 4392Spring Properties Reloaded Som ... -
为spring2.5中的jpetstore增加perf4j监控
2010-09-02 13:51 2669perf4j是一款类似于log4j的性能检测工具. 它 ... -
语义网的学习资源大汇集(备忘)
2010-06-23 22:48 1780网上资源 http:/ ... -
使用 JOLAP 实现复杂分析查询
2010-06-06 13:42 1983Shashank Tiwari 在本文中对 ... -
HTML5 Canvas for Internet Explorer
2010-06-04 21:16 1869Canvascape http://www.benjoff ... -
大型网站架构演变和知识体系
2010-06-01 23:47 2002架构演变第一步:物 ...
相关推荐
接口是采用中立的方式进行定义的,它应该独立于实现服务的硬件平台、操作系统和编程语言。这使得服务可以以一种统一和通用的方式进行交互。 - **特点**: - **松散耦合**: 服务之间通过接口进行通信,减少了依赖关系...
11KW OBC两电平pfc+cllc仿真源码实现:单相与三相兼容版双向控制研究,11KW OBC两电平pfc+cllc仿真源码实现:单相与三相兼容版,实现双向控制策略,11KW OBC两电平pfc+cllc仿真,源代码实现。 注意:已成单相,三相兼容版仿真文件。 双向控制。 ,核心关键词:11KW OBC两电平pfc; CLLC仿真; 源代码实现; 单相三相兼容; 双向控制。,11KW OBC单相与三相兼容版仿真:两电平PFC+CLLC双向控制源代码实现
3GPP R15 38.331 5G NR无线资源控制(RRC)协议规范解析
五运六气YUNQI_V471_SRC_D1023
19考试真题最近的t63.txt
基于MATLAB的牛拉法电力系统潮流计算程序,结合BPA方法,附参考文献,适合基础学习与拓展创新,基于MATLAB的牛拉法电力系统潮流计算程序:涵盖基础学习与拓展创新,附参考文献,牛拉法电力系统潮流计算 MATLAB编写潮流计算程序 BPA计算潮流 另外包含参考文献 这个程序把潮流计算的一般流程包括了,非常适合基础学习,并进一步的进行拓展创新 ,牛拉法; 电力系统潮流计算; MATLAB; BPA计算; 程序编写; 流程; 基础学习; 创新拓展,基于MATLAB的牛拉法电力系统潮流计算程序:基础学习与拓展创新指南
YOLOv11m权重文件
高一-语文-2025年1月张家界市高一期末联考-缺考不计、违纪不计、0分不计_2025-01-16-12-21 (1).zip
android kotlin 版本的贪吃蛇游戏
19考试真题最近的t57.txt
基于疫情封控区域的生活物资配送优化模型:结合遗传算法与模拟退火,实现时间最短和综合满意率最高的路径优化。,疫情下封控区域生活物资配送优化模型:结合遗传算法与模拟退火算法求解路径优化问题,实现时间与满意率双重目标优化。,模型及MATLAB代码:考充分考虑并结合疫情下封控区域生活物资配送问题及车辆路径问题的特点构建物资配送优化模型。 在一般单一目标——时间最短的基础上,加入综合满意率优化目标的路径优化问题 关键词:遗传算法、改进、模拟 火算法,路径优化、CVRP 完整模型+代码+注释 主要内容:以配送时间最短及综合满足率最高为目标,充分考虑并结合疫情下封控区域生活物资配送问题及车辆路径问题的特点构建物资配送优化模型,为疫情下生活物资配送找到了更好的思路。 在模型设计与求解问题上,首先设计标准遗传算法,继而对算法加以改进,最后设计出了改进遗传-模拟 火算法对模型进行求解。 还有参数灵敏度分析等。 服务内容:脚本 工具 部分展示如下: ,关键词:疫情下物资配送;车辆路径问题;优化模型;遗传算法;改进;模拟退火算法;CVRP;参数灵敏度分析;脚本工具;时间最短;综合满意率。 核心关键词用分号分
## 01、数据介绍 动态能力理论最早由提斯(Teece)与皮萨洛(Pisano)于1994年正式提出,他们将动态能力定义为“能够创造新产品和新过程,以及对变化的市场环境做出响应的一系列能力”。 动态能力具体体现在吸收能力、创新能力和适应能力三个方面。这些能力使公司能够快速适应市场变化,抓住新的商业机会,从而保持或提升竞争优势。 数据名称:上市公司-动态能力数据 数据年份:2012-2023年 ## 02、相关数据及指标 证券代码 证券名称 年份 Symbol RD IA ACV DC
基于ASIO的插件式服务器,支持TCP, UDP, 串口,Http, Websocket,统一化的数据接口,隔离开发人员和IO之间的操作。可以快速迭代。PSS 是针对不同 IO 逻辑的插件管理系统。您可以忽略 IO 建立的细节,构建自己的 logic 应用程序。PSS 封装了 Tcp、udp、kcp、串行端口、http、websocket 和 ssl 的统一接口。您可以使用 配置文件 或 统一接口 来创建和使用它们。logic plug-in 是完成数据到达后的 logic 处理,全部以动态库的形式加载,将 IO 和 logic 本身的耦合分开。简单的逻辑开发。本项目由三部分组成 (1) 主机(2) 数据包分析插件(3) 逻辑处理插件。您可以实现后两个插件来完成您的业务逻辑部署。
电机控制器源码:通用无感BLDC方波控制,高效参数化启动,转速达12w,环控系统一键调节,电机控制器源码:通用无感BLDC方波控制,高效调速,参数宏定义便捷调试,最高电转速达12w,电机控制器,低压无感BLDC方波控制,全部源码,方便调试移植 1.通用性极高,图片中的电机,一套参数即可启动。 2. ADC方案 3.电转速最高12w 4.电感法和普通三段式 5.按键启动和调速 6.开环,速度环,限流环 7.参数调整全部宏定义,方便调试 代码全部源码 ,电机控制器;低压无感BLDC方波控制;全部源码;通用性极高;电转速最高12w;电感法与普通三段式;按键启动调速;开环、速度环、限流环;参数调整宏定义。,通用电机控制器:低压无感BLDC方波控制源码,支持高转速12W,便捷调试移植
基于MPC的电动汽车分布式协同自适应巡航控制:上下分层控制与仿真结果展示,基于MPC的电动汽车协同自适应巡航控制:上下分层控制与仿真结果展示,基于MPC的分布式电动汽车协同自适应巡航控制,采用上下分层控制方式,上层控制器采用模型预测控制mpc方式,产生期望的加速度,下层根据期望的加速度分配扭矩;仿真结果良好,能够实现前车在加减速情况下,规划期望的跟车距离,产生期望的加速度进行自适应巡航控制。 ,关键词:MPC(模型预测控制); 分布式电动汽车; 协同自适应巡航控制; 上下分层控制方式; 期望加速度; 扭矩分配; 仿真结果良好; 前车加减速; 跟车距离。,基于MPC的分层控制电动汽车自适应巡航系统,仿真实现前车加减速跟车距离自适应
多维度购电与售电模型构建及基于CVaR与WOA优化的收益风险评估方法研究,基于CVaR风险评价及WOA优化的新型售电公司购售电模型与策略仿真研究,建立了一个电公司的购电侧模型和电侧模型,其中购电侧模型包括长期市场业务,现市场业务,可再生能源购电市场业务,分布式电源购电市场业务以及储能租赁市场业务五种类型。 电侧包括均 电价合同和实时电价合同两种类型。 然后在购电模型的基础上,提出了一种基于CVaR的购电收益风险评价方法。 根据电公司的CVaR购电收益风险数学模型,提出了一种基于WOA优化算法的新型购电收益计算方法。 该方法将购电收益风险计算公式作为WOA优化算法的目标函数,然后通过WOA的鲸鱼行走觅食、鲸鱼包围以及鲸鱼螺旋捕食三个步骤计算电公司的最优购电策略。 最后,通过MATLAB仿真工具对本文所研究的基于WOA优化的新型购电收益计算方法进行了仿真分析。 仿真结论验证了通过WOA优化算法得到的购电策略为最优购电策略。 matlab代码 仿真平台:MATLAB平台 代码具有一定的深度和创新性,注释清晰 ,关键词: 1. 购电侧模型; 2. 售电侧模型; 3. 长期/现货/可再生
迅雷软件下载原理介绍.md
## 01、数据简介 碳排放是指在人类活动中,如能源消耗、工业生产、交通运输、农业活动等过程中向大气中释放的二氧化碳等温室气体的行为。这些温室气体在大气中形成隔热层,导致地球气温升高,引发全球气候变化。分行业碳排放则是指按照不同的经济活动或产业部门来划分和统计碳排放量。 按省市县整理成面板数据,其中包括电力行业、工业过程、工业燃烧、建筑物能源、浪费、农业、燃料能源和运输八种指标排放量各省市县的最大值、最小值、平均值、总和。 数据名称:省市县分行业碳排放月度数据 数据年份:2023年 ## 02、相关数据 name 指标 时间 数值 更多数据 ## 03、数据截图
基于OpenCV 相机校准 姿势估计 线性几何 立体图像的深度图