您的位置:首页 > 其它

Mule ESB 学习笔记(2)

2014-06-15 21:50 423 查看
6. 配置模式

Mule 3.0版本提供了“pattern”的机制。Pattern总结了实际使用过程中的常见场景,以简化的服务配置方式提供。

6.1 简单服务模式(simple service pattern)

简单服务模式用于简化同步服务调用的配置,对应消息传递方式中的请求-响应方式。





图 简单服务模式

简单服务模式通过simple-service 元素配置,主要的元素属性包括:

属性说明
address服务监听的地址,如vm:in
component-classComponent的实现类
typedirect: 默认;

jax-ws: 将component暴露为soap式的web service(component必须基于jax-ws的注解),address一般为Http Transport;

jax-rs: 将component暴露为rest式的web service(component必须基于@Path的注解),address一般为Http或Servlet Transport
代码示例:

<simple-service name="simple-service" address="vm://simple.in"
component-class="demo.mule.umo.Echo" />

Mule针对服务请求接入可以做额外的处理,比如增加Transformer配置进行数据转换。

6.2 桥接模式(bridge pattern)

桥接模式用于在inbound endpoint和outbound endpoint之间建立直接连接,不需要component提供业务逻辑。





图 桥接模式

桥接模式通过bridge元素配置,主要属性包括:

属性说明
inboundAddress服务请求接入地址
outboundAddress服务接出的实际地址
exchange-patternrequest-response: 默认,返回处理结果;

one-way: 单向

transactedtrue: 在向outbound endpoint分发时使用事务;

false: 不使用事务

代码示例:

<bridge name="queue-to-topic" transacted="true" inboundAddress="jms://myQueue"
outboundAddress="jms://topic:myTopic" />

Mule在接入、接出的过程中可以做额外的处理,比如增加Transformer配置进行数据转换。如果使用事务控制,对于异构的协议之间的事务需要有支持XA的事务控制器。

6.3 校验器模式(validator pattern)

校验器模式通过定义一个校验过滤器过滤服务请求,并同步返回ACK(ACKnowledge)或NACK(Not Acknowledge)结果。通过校验的服务请求被异步分发给处理方。




图 校验器模式
校验器模式通过validator元素配置,主要属性包括:

属性说明
inboundAddress服务请求接入地址
outboundAddress服务接出地址
ackExpression表达式,用于构建服务请求被接收时的信息
nackExpression表达式,用于构建服务请求被拒绝时的信息
errorExpression@since 3.0.1

表达式,用于构建在服务请求分发出错时的信息
validationFilter-ref过滤器的引用,也可以使用子元素指定

用于确定服务请求是否被接收
代码示例:

<validator name="integer-validator" inboundAddress="vm://validator.in"
ackExpression="#[string:GOOD:#[message:payload]@#[context:serviceName]]"
nackExpression="#[string:BAD:#[message:payload]@#[context:serviceName]]"
outboundAddress="vm://test-service.in">
<payload-type-filter expectedType="java.lang.Integer" />
</validator>

注:Mule的表达式后续补充。

6.4 web服务代理模式(web service proxy pattern)

Web服务代理模式用于将Web Service请求直接转发至远程目标Web Service服务端,Mule本身不提供实际的Web Service。




图 web服务代理模式
Web服务代理模式通过ws-proxy元素配置,主要属性包括:

属性说明
inboundAddressMule对外提供的地址
outboundAddressWeb Service的实际地址
代码示例:

<ws:proxy name="ws-proxy"
inboundAddress="http://localhost:7006/services/Echo"
outboundAddress="http://localhost:8000/services/Echo?method=echo">
</ws:proxy>
Mule在转发的过程中可以做额外的处理,比如增加Transformer配置进行数据转换。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  esb soap JMS SOA Mule