0

我正在尝试使用 Camel、Spring 和 ActiveMQ实现请求-回复模式。我需要做的是逐行读取 CSV 文件。然后对于每一行:

  1. 根据 CSV 中的行值构造请求
  2. 将请求发送到队列
  3. 其他组件需要接收消息,处理请求并将响应发送到另一个消息队列(生产者知道,因此生产者可以接收响应)。

我得到了下面的代码。现在让我们说在处理器中我创建了响应。

我的问题是:

  1. 我怎样才能发回响应?
  2. 如何使用响应?

public class MyRouteBuilder extends RouteBuilder {

    public static void main(String[] args) throws Exception {
        new Main().run(args);
    }

    public void configure() {
        from("file:/Users/aviad/ws/integ/src/data?fileName=lines.txt&noop=true&idempotent=true")
        .split()
        .tokenize("\\n")
        .inOut("activemq:req");

        from("activemq:req")
        .process(new Processor() {
            public void process(Exchange exchange) throws Exception {
                System.out.println(exchange.getIn().getBody(String.class));
                System.out.println("jmscorrelationid=" + exchange.getIn().getHeader("jmscorrelationid"));
                System.out.println("jmsdestination=" + exchange.getIn().getHeader("jmsdestination"));
            }
        });
    }
}
4

1 回答 1

2

如果传入的 JMS 消息上设置了 JMSReplyTo,Camel 会自动发送回响应。因此,在您的第二条路由中,当消息到达路由的末尾时,JMS 消费者将使用给定的 JMSCorrelationID 将消息“按其当前状态”作为回复消息发送回 JMSReplyTo 目的地。

您可以在 JMS 端点上设置许多选项来禁用自动发回回复。或者指定一个命名的回复队列等。有关其所有选项,请参见 JMS 页面:http: //camel.apache.org/jms

当您从第一条路线使用 inOut 时,Camel 将通过 JMS 进行请求-回复。默认情况下,它使用临时队列。但是你也可以告诉 Camel 使用命名队列(我们称之为固定队列)。请参阅 JMS 文档:http ://camel.apache.org/jms

请注意 JMS 页面顶部的提示:http: //camel.apache.org/jms。它向您介绍页面上有关请求/回复的详细信息的部分。所以去读吧。

于 2013-04-29T06:20:04.667 回答