Camel RabbitMQ 请求响应模式示例

Camel RabbitMQ Request Response Pattern Example

我正在寻找使用 Camel RabbitMQ 请求响应模式的示例代码。

我的用例: - 请求消息存放在 RabbitMQ 队列中 - Camel 路由使用消息,调用外部 Web 服务,并根据消息的回复属性回复响应

我也使用 Spring AMQP 实现这个用例,但我也想用 Camel RabbitMQ 来实现。

骆驼文档:http://camel.apache.org/rabbitmq.html

感谢您的帮助。

阿尔诺

我找到了解决方案:

Camel RabbitMQ Reply-To 功能将出现在下一个 Camel Release 2.15 中。

比照。 https://issues.apache.org/jira/browse/CAMEL-7860

阿尔诺

这是一个HTTP代理的简单例子。 HTTP 请求通过 Rabbit MQ,HTTP 响应返回给 Rabbit MQ。

在 camel 2.17.1 上编写的示例(camel-core、camel-netty4-http、camel-rabbitmq)

示例调用:

curl -H "proxy_url:http://remotehost:port/uri" 127.0.0.1

    context.addRoutes(new RouteBuilder() {

        @Override
        public void configure() throws Exception {

            from("netty4-http:localhost:80").
                    to("rabbitmq://localhost:5672/async");

            from("rabbitmq://localhost:5672/async").
                    process(exchange -> {

                        // for return not only 200 HTTP STATUS
                        String techParams = "throwExceptionOnFailure=false";
                        String proxyUrl = (String) exchange.getIn().getHeader("proxy_url");

                        proxyUrl = proxyUrl.contains("?") && proxyUrl.contains("=") 
                                ? proxyUrl + "&" + techParams : proxyUrl + "?" + techParams;
                        exchange.getIn().setHeader("proxy_url", proxyUrl);

                        exchange.setProperty(RabbitMQConstants.CORRELATIONID, 
                                exchange.getIn().getHeader(RabbitMQConstants.CORRELATIONID));

                    }).
                    toD("netty4-http:${header.proxy_url}").
                    process(exchange -> {
                        exchange.getIn().setHeader(RabbitMQConstants.CORRELATIONID, exchange.getProperty(RabbitMQConstants.CORRELATIONID));
                    });
        }

    });