通過MULE整合服務的幾種方式
6. 配置模式
Mule 3.0版本提供了“pattern”的機制。Pattern總結了實際使用過程中的常見場景,以簡化的服務配置方式提供。
6.1 簡單服務模式(simple service pattern)
簡單服務模式用於簡化同步服務呼叫的配置,對應訊息傳遞方式中的請求-響應方式。
圖 簡單服務模式
簡單服務模式通過simple-service 元素配置,主要的元素屬性包括:
屬性 | 說明 |
address | 服務監聽的地址,如vm:in |
component-class | Component的實現類 |
type |
direct: 預設; jax-ws: 將component暴露為soap式的web service(component必須基於jax-ws的註解),address一般為Http 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-pattern |
request-response: 預設,返回處理結果; one-way: 單向 |
transacted |
true: 在向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元素配置,主要屬性包括:
屬性 | 說明 |
inboundAddress | Mule對外提供的地址 |
outboundAddress | Web Service的實際地址 |
程式碼示例:
<ws:proxy name="ws-proxy" inboundAddress="http://localhost:7006/services/Echo" outboundAddress="http://localhost:8000/services/Echo?method=echo"> </ws:proxy>
Mule在轉發的過程中可以做額外的處理,比如增加Transformer配置進行資料轉換。