ActiveMQ与RabbitMQ使用camel集成


         著名的EIP实现框架Camel最早起源于ActiveMQ内的一些基于消息的集成需求,然后逐渐发展成为一个ActiveMQ的子项目,最后这一块的功能越来越完善,就成为了Apache的顶级项目。

         所以,从一开始到现在,ActiveMQ与Camel这两个项目一直都是紧密联系的,可以非常方便的整合使用:比如在ActiveMQ的配置文件中直接按照Spring的配置方式使用Camel来实现ActiveMQ与其他外部系统或中间件的集成。而ActiveMQ中的一些简单的集成功能也越来越倾向于直接去掉或者移植到Camel环境中去实现。

环境:ActiveMQ 5.9.0、RabbitMQ3.3.0、

一、ActiveMQ与ActiveMQ的集成

实现一个简单的从一个Queue到另一个Queue的消息转发。

1.        在activemq.xml中加一句:<import resource="camel.xml"/>

2.        加一个简单路由,从队列example.A转发消息到队列example.B,camel.xml的内容为:

<beans
  xmlns="http://www.springframework.org/schema/beans" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="
    http://camel.apache.org/schema/springhttp://camel.apache.org/schema/spring/camel-spring.xsd
    http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsd">
 
   <camelContext id="camel"xmlns="http://camel.apache.org/schema/spring">
       <route>
           <description>Example Camel Route</description>
           <from uri="activemq:example.A"/>
           <to uri="activemq:example.B"/>
       </route>
   </camelContext>
 
   <bean id="activemq"class="org.apache.activemq.camel.component.ActiveMQComponent" >
       <property name="connectionFactory">
         <beanclass="org.apache.activemq.ActiveMQConnectionFactory">
           <property name="brokerURL"value="vm://localhost?create=true"/>
           <property name="userName"value="${activemq.username}"/>
           <property name="password" value="${activemq.password}"/>
         </bean>
       </property>
   </bean>
</beans>

 3.        启动ActiveMQ后,浏览器输入http://localhost:8161/admin/queues.jsp,可以看到自动创建了一个队列example.A,并且加了一个消费者。


4.        点击Send To,发送一个消息到example.A,刷新页面,可以看到消息已经被转发:

  

二、ActiveMQ与RabbitMQ集成

详细的配置参数:http://camel.apache.org/rabbitmq.html

Ø  从RabbitMQ路由消息到ActiveMQ

1.        Camel里添加AMQP的路由如下:

	<route>
           <from uri="rabbitmq://localhost/t?username=guest&password=guest&exchangeType=topic&autoDelete=false&queue=t"/>
           <to uri="activemq:example.fromRMQ"/>
       </route>

2.        复制camel中的camel-rabbitmq-2.13.0.jar 和rabbitmq-java-client中的rabbitmq-client.jar到apache-activemq-5.9.0\lib\camel下。

3.        重启ActiveMQ,在rabbitmq的控制台可以看到自动创建的exchange为t,

 

4.        在rabbitmq控制台向t中发送消息,


5.        刷新ActiveMQ控制台可以看到消息已经从rabbitmq路由到activemq:


 

Ø  从ActiveMQ路由消息到Rabbitmq

1.        在camel.xml中添加配置:

       <route>
           <from uri="activemq:test"/>
           <to uri="rabbitmq://localhost/?username=guest&password=guest&exchangeType=topic&autoDelete=false&queue=test"/>
       </route>
2.        重启ActiveMQ后,在控制台可以看到新增的队列test,

3.        往ActiveMQ的test队列发送一个消息。

4.        写个简单程序从Rabbitmq的队列test接收消息:

说明消息已经转发从ActiveMQ到RabbitMQ了。

各软件下载地址:

  1. 下载安装erlang:http://www.erlang.org/download.html
  2. 下载解压rabbitmq zip版本及java bin client zip:http://www.rabbitmq.com/download.html
  3. 添加控制台:http://www.rabbitmq.com/management.html
  4. Camel下载:http://camel.apache.org/download.html
  5. ActiveMQ下载:http://activemq.apache.org/download.html

 

 

  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
### 回答1: ActiveMQRabbitMQ都是流行的消息队列软件,它们的主要区别在于: 1. 语言支持:ActiveMQ是用Java编写的,而RabbitMQ是用Erlang编写的,因此RabbitMQ在处理高并发和高吞吐量时更加出色。 2. 协议支持:ActiveMQ支持多种协议,包括OpenWire、Stomp、AMQP和MQTT等,而RabbitMQ主要支持AMQP协议。 3. 可靠性:RabbitMQ在消息传递方面更加可靠,因为它使用了一些高级特性,如事务和确认机制。 4. 性能:RabbitMQ的性能比ActiveMQ更好,因为它使用了一些高级技术,如预取和流控制等。 总之,如果你需要处理高并发和高吞吐量的消息传递,那么RabbitMQ可能是更好的选择。如果你需要支持多种协议和更灵活的配置选项,那么ActiveMQ可能更适合你。 ### 回答2: ActiveMQRabbitMQ都是开源的消息中间件,它们都有自己独特的优势和适用场景。 ActiveMQ是基于Java的消息队列系统,它支持Java Messaging Service(JMS)标准,并且可以通过许多编程语言访问。ActiveMQ支持多种协议,如AMQP、MQTT、OpenWire和STOMP,且其性能较高,适合处理大量消息。ActiveMQ还提供了许多高级功能,如分布式事务、消息持久性、监视和管理等。此外,ActiveMQ还具有高可用性、冗余性和容错性等特点。 而RabbitMQ则是基于Erlang语言开发的,它支持AMQP(Advanced Message Queueing Protocol)和许多高级消息队列特性,如异步通信、消息确认、消息持久性和发布/订阅模式等。RabbitMQ还支持多种客户端库,包括Java、.NET、Python、Ruby和PHP等,适用于各种不同的应用场景。RabbitMQ还提供了许多插件和扩展,如消息转发器、集群和管理插件等,可以适应大量数据流量的需求。 在实际应用中,选择使用哪种消息队列系统取决于应用的具体需求和场景。如果需要高性能、高可用性、高容错性和高度分布式,则可以选择ActiveMQ。如果需要可扩展性、弹性、多语言支持和丰富插件,则可以选择RabbitMQ。当然,在选择之前,需要对这两个开源项目的详细了解和比较,以便能够选择最适合特定应用场景的消息队列系统。 ### 回答3: ActiveMQRabbitMQ是两种主要的消息队列中间件。它们在功能和性能方面均有很大的不同,这里将会深入探讨它们之间的差异。 首先是它们的架构和工作原理。ActiveMQ的架构是基于Java消息服务规范的,可以在Java、C++、Python等多种语言中运行。RabbitMQ是基于AMQP协议的,它是一种面向消息的中间件协议,用于消息传递、路由和连接的标准。ActiveMQ使用JMS作为应用程序接口,而RabbitMQAMQP基础上提供了自己的AMQP实现代码。所以,ActiveMQ更适合面向Java开发人员,而RabbitMQ适合更广泛的应用场景。 其次是它们的性能和可扩展性。ActiveMQ具有较好的水平扩展性,可以构建集群,并且可以将消息持久化到磁盘中以进行高可靠性。但是它的性能往往不如RabbitMQRabbitMQ具有出色的消息处理性能,并能够处理大量的并发请求。它使用预取机制来提高性能,这意味着RabbitMQ将尽可能提供更多消息,使客户机可以更快地处理它们。 再次是它们的功能和应用场景。ActiveMQ提供了许多高级功能,如消息过滤、消息路由、消息事务等,非常适合大规模企业级应用程序。RabbitMQ适用于需要高吞吐量的场景,如物联网、游戏、金融等领域。RabbitMQ还提供了一些高级功能,如发布/订阅、主题路由等。 总的来说,ActiveMQRabbitMQ都有各自的优点和缺点,开发者应该根据自己的特定需求选择适合的中间件。如果需要建立高度可靠的企业应用程序,应选择ActiveMQ。如果需要高可扩展性和高吞吐量的大规模应用程序,则应使用RabbitMQ
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kimmking

赠人玫瑰手有余香

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值