ActiveMQ使用介绍及实例
上一篇讲了rabbitmq的使用以及demo,activemq的思路也与之有相似的地方。
activemq是基于Java实现的。activemq没有rabbitmq那么多的路由规则,其通信方式只有两种,queue和topic。
1.queue又称P2P模式:
一条消息仅能传递给一个消息消费者。
如果多个消息消费者正在监听队列上的消息,JMS消息服务器将根据“先来者优先”的原则确定由哪个消息消费者接收下一条消息。
如果没有消息消费者在监听队列,消息将保留在队列中,直至消息消费者连接到队列为止。这种消息传递模型是传统意义上的懒模型或轮询模型。
在此模型中,消息不是自动推动给消息消费者的,而是要由消息消费者从队列中请求获得。
2.topic又称pub/sub模式(发布订阅模式):
消息首先由消息生产者发布至消息服务器中特定的主题中,然后由消息服务器将消息传送至所有已订阅此主题的消费者。
直接给出demo吧,也挺简单。与spring的整合是采用jmsTemplate进行操作的
入门级实例 https://github.com/littlechaser/activemq.git
与springMVC整合 https://github.com/littlechaser/SpringActiveMQ.git
在与spring整合的demo中,调sendMsg接口
得到结果如下:
多次调用,每次都可能不一样,但是consumer、consumer2、consumer3三者只有一个能获得消息。
调用sendMsg2接口:
得到结果为:
可见,所有消费者都获得了消息,这就是p2p和pub/sub模式两者的实现及区别。