ActiveMQ - 我无法使用InOut模式使用Camel发送的消息

问题描述 投票:1回答:2

ActiveMQ 5.5.1

<c:route>
    <c:from uri="jetty:http://0.0.0.0:8055/ws/despacho" />
    <c:to uri="bean:despachoHandler" />
    <c:to uri="activemq:queue:copom.out.test" pattern="InOut" />
</c:route>

消息显示排队,但我无法使用它。一段时间后,我得到超时,消息转到ActiveMQ.DLQ。

org.apache.camel.ExchangeTimedOutException:未收到OUT消息:20000毫秒到期回复消息,其中relatedID:Camel-ID-SSP-SGPF-GITSAD-58215-1359134232568-0-3未收到。

如果我将其更改为pattern =“InOnly”,我可以正常使用该消息。

这是怎么回事?

jms activemq apache-camel
2个回答
11
投票

你应该学习EIP模式。

使用InOut时,您正在执行请求 - 回复EIP模式http://camel.apache.org/request-reply.html

在这种情况下,消息被发送到JMS队列,并且与InOut一样,然后期望回复消息被发送回JMSReply属性中定义的队列(如果没有,Camel将设置为临时队列名称)否则显式设置)。

如果20秒后没有回复消息,Camel会因超时异常而失败。您可以配置超时的长度。

所以你必须决定你是在做一个请求回复EIP(InPut)还是一个事件消息(In Only)qazxsw poi


0
投票

当JMSCorrelationID =设置了我们的系统并且Camel输入/输出无法从请求应答队列接收响应时,我们遇到了类似的问题。在删除由我们的代码设置的JMSCorrelationID =时,Camel开始成功地从Request Reply队列接收消息。

© www.soinside.com 2019 - 2024. All rights reserved.