我正在尝试构建一条将执行以下操作的路线:
jms:sender-in.我正在使用INOUT请求回复模式.该JMSReplyTo = sender-outjms:consumer1-in,jms:consumer2-in和jms:consumer3-in.所有人都在使用请求回复模式.在 JMSReplyTo每消费指定(在这种情况下,JMSReplyTo在这个顺序jms:consumer1-out, jms:consumer2-out, jms:consumer3-outjms:sender-out.我构建了一条类似于此的路线:
from("jms:sender-in")
.to("jms:consumer1-in?exchangePattern=InOut&replyTo=queue:consumer1-out&preserveMessageQos=true")
.to("jms:consumer2-in?exchangePattern=InOut&replyTo=queue:consumer2-out&preserveMessageQos=true")
.to("jms:consumer3-in?exchangePattern=InOut&replyTo=queue:consumer3-out&preserveMessageQos=true");
Run Code Online (Sandbox Code Playgroud)
然后我将回复发送回某个队列以收集和聚合:
from("jms:consumer1-out?preserveMessageQos=true").to("jms:gather");
from("jms:consumer1-out?preserveMessageQos=true").to("jms:gather");
from("jms:consumer1-out?preserveMessageQos=true").to("jms:gather");
from("jms:gather").aggregate(header("TransactionID"), new GatherResponses()).completionSize(3).to("jms:sender-out");
Run Code Online (Sandbox Code Playgroud)
为了模仿我的消费者的行为,我添加了以下路线:
from("jms:consumer1-in").setBody(body());
from("jms:consumer2-in").setBody(body());
from("jms:consumer3-in").setBody(body());
Run Code Online (Sandbox Code Playgroud)
我有几个问题:
我有一种感觉,我正在努力解决一些基本概念.任何帮助表示赞赏.谢谢.
一个好问题!
您需要考虑两件事
我做了两个与你的情况类似的例子 - 一个有Request Reply,另一个有(单向)事件消息.
随意用jms替换activemq组件 - 在这些示例中它是相同的.
示例一,使用事件消息 - InOnly:
from("activemq:amq.in")
.multicast()
.to("activemq:amq.q1")
.to("activemq:amq.q2")
.to("activemq:amq.q3");
from("activemq:amq.q1").setBody(constant("q1")).to("activemq:amq.gather");
from("activemq:amq.q2").setBody(constant("q2")).to("activemq:amq.gather");
from("activemq:amq.q3").setBody(constant("q3")).to("activemq:amq.gather");
from("activemq:amq.gather")
.aggregate(new ConcatAggregationStrategy())
.header("breadcrumbId")
.completionSize(3)
.to("activemq:amq.out");
from("activemq:amq.out")
.log("${body}"); // logs "q1q2q3"
Run Code Online (Sandbox Code Playgroud)
示例二,使用Request reply - 请注意散射路径必须在响应时收集响应.结果与第一个示例相同,但路由较少且配置较少.
from("activemq:amq.in2")
.multicast(new ConcatAggregationStrategy())
.inOut("activemq:amq.q4")
.inOut("activemq:amq.q5")
.inOut("activemq:amq.q6")
.end()
.log("Received replies: ${body}"); // logs "q4q5q6"
from("activemq:amq.q4").setBody(constant("q4"));
from("activemq:amq.q5").setBody(constant("q5"));
from("activemq:amq.q6").setBody(constant("q6"));
Run Code Online (Sandbox Code Playgroud)
至于你的问题二 - 当然,可以传递JMSReplyTo标题并强制交换模式 - 但是你将创建难以调试的代码.保持您的交换模式简单和干净 - 它可以防止错误.
| 归档时间: |
|
| 查看次数: |
1054 次 |
| 最近记录: |