博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
activeMq学习
阅读量:5788 次
发布时间:2019-06-18

本文共 8736 字,大约阅读时间需要 29 分钟。

一、activeMq有两种消息模式

1、点对点的消息模式

点对点的模式主要建立在一个队列上面,当连接一个列队的时候,发送端不需要知道接收端是否正在接收,可以直接向ActiveMQ发送消息,发送的消息,将会先进入队列中,如果有接收端在监听,则会发向接收端,如果没有接收端接收,则会保存在activemq服务器,直到接收端接收消息,点对点的消息模式可以有多个发送端,多个接收端,但是一条消息,只会被一个接收端给接收到,哪个接收端先连上ActiveMQ,则会先接收到,而后来的接收端则接收不到那条消息

2、订阅模式

订阅/发布模式,同样可以有着多个发送端与多个接收端,但是接收端与发送端存在时间上的依赖,就是如果发送端发送消息的时候,接收端并没有监听消息,那么ActiveMQ将不会保存消息,将会认为消息已经发送,换一种说法,就是发送端发送消息的时候,接收端不在线,是接收不到消息的,哪怕以后监听消息,同样也是接收不到的。这个模式还有一个特点,那就是,发送端发送的消息,将会被所有的接收端给接收到,不类似点对点,一条消息只会被一个接收端给接收到。

二、项目介绍

所需要工具和框架 需要

项目框架采用springmvc

三、代码实现

1、消息生产者

点对点模式

package com.cc.activemq.mq.producer.queue;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.Session;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.jms.core.JmsTemplate;import org.springframework.jms.core.MessageCreator;import org.springframework.stereotype.Component;@Component("queueSender")public class QueueSender1 {    /**     * 通过Qualifier注入对象bean     */    @Autowired    @Qualifier("jmsQueueTemplate")    private JmsTemplate jmsTemplate;    /**     *  * Description: 
* 发送消息到指定的队列 * * @author chenchao * @date 2017年6月9日 12:18:22 * @param queueName * 队列名称 * @param message * 消息内容 */ public void send(String queueName, final String message) { jmsTemplate.send(queueName, new MessageCreator() { public Message createMessage(Session session) throws JMSException { return session.createTextMessage(message); } }); }}

订阅模式

package com.cc.activemq.mq.producer.topic;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.Session;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.jms.core.JmsTemplate;import org.springframework.jms.core.MessageCreator;import org.springframework.stereotype.Component;/** * ActiveMQ的topic/sub模式 Description: 
* Topic生产者发送消息到Topic * * @author chenchao * @date 2017年6月9日 12:19:05 * */@Component("topicSender")public class TopicSender1 { @Autowired @Qualifier("jmsTopicTemplate") private JmsTemplate jmsTemplate; /** * 发送一条消息到指定的队列(目标) * * @param queueName * 队列名称 * @param message * 消息内容 */ public void send(String topicName, final String message) { jmsTemplate.send(topicName, new MessageCreator() { public Message createMessage(Session session) throws JMSException { return session.createTextMessage(message); } }); }}

controller调用

package com.cc.activemq.controller;import javax.annotation.Resource;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestMethod;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.ResponseBody;import com.cc.activemq.mq.producer.queue.QueueSender1;import com.cc.activemq.mq.producer.topic.TopicSender1;/** * Description: 
* * @author chenchao * @date 2017年6月9日 14:03:03 * */@Controller@RequestMapping("activemq")public class ActivemqController1 { @Resource private QueueSender1 queueSender; @Autowired private TopicSender1 topicSender; /** * 点对点模式 主要建立在一个队列上面,当连接一个列队的时候,发送端不需要知道接收端是否正在接收,可以直接向ActiveMQ发送消息,发送的消息, * 将会先进入队列中 * ,如果有接收端在监听,则会发向接收端,如果没有接收端接收,则会保存在activemq服务器,直到接收端接收消息,点对点的消息模式可以有多个发送端 * ,多个接收端,但是一条消息,只会被一个接收端给接收到,哪个接收端先连上ActiveMQ,则会先接收到,而后来的接收端则接收不到那条消息 * 发送消息到队列 Queue队列:仅有一个订阅者会收到消息,消息一旦被处理就不会存在队列中 * * @param message * @return String */ @ResponseBody @RequestMapping(value="queueSender",method=RequestMethod.GET,produces = "application/json; charset=utf-8") public String queueSender(@RequestParam("message")String message) { String opt = ""; try { queueSender.send("test.queue", message); System.out.println(message); opt = message; } catch (Exception e) { opt = e.getCause().toString(); } return opt; } /** * 订阅/发布模式,同样可以有着多个发送端与多个接收端,但是接收端与发送端存在时间上的依赖,就是如果发送端发送消息的时候,接收端并没有监听消息, * 那么ActiveMQ将不会保存消息 * ,将会认为消息已经发送,换一种说法,就是发送端发送消息的时候,接收端不在线,是接收不到消息的,哪怕以后监听消息,同样也是接收不到的 * 。这个模式还有一个特点,那就是,发送端发送的消息,将会被所有的接收端给接收到,不类似点对点,一条消息只会被一个接收端给接收到。 * * @param message * @return */ @ResponseBody @RequestMapping("topicSender") public String topoicSender(@RequestParam("message") String message) { String opt = ""; try { topicSender.send("test.topic", message); opt = "suc"; } catch (Exception e) { opt = e.getCause().toString(); } return opt; }}

2、消息消费者

点对点模式(消息队列模式)

package com.cc.activemq.mq.consumer.queue;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.MessageListener;import javax.jms.TextMessage;import org.springframework.stereotype.Component;/**  * Description: 
* 消息队列监听器 * @author hetiewei * @date 2017年6月9日 11:40:02 * */ @Componentpublic class QueueReceiver1 implements MessageListener{ @Override public void onMessage(Message message) { try { System.out.println("QueueReceiver1接收到消息"+((TextMessage)message).getText()); } catch (JMSException e) { e.printStackTrace(); } }}
package com.cc.activemq.mq.consumer.queue;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.MessageListener;import javax.jms.TextMessage;import org.springframework.stereotype.Component;/**  * Description: 
* 消息队列监听器 * @author chenchao * @date 2017年6月9日 11:40:37 * */ @Componentpublic class QueueReceiver2 implements MessageListener{ @Override public void onMessage(Message message) { try { System.out.println("QueueReceiver2接收到消息"+((TextMessage)message).getText()); } catch (JMSException e) { e.printStackTrace(); } }}

订阅模式

package com.cc.activemq.mq.consumer.topic;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.MessageListener;import javax.jms.TextMessage;import org.springframework.stereotype.Component;@Componentpublic class TopicReceiver1 implements MessageListener {    @Override    public void onMessage(Message message) {         try {                  System.out.println("TopicReceiver1接收到消息"+((TextMessage)message).getText());              } catch (JMSException e) {                  e.printStackTrace();              }      }}
package com.cc.activemq.mq.consumer.topic;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.MessageListener;import javax.jms.TextMessage;import org.springframework.stereotype.Component;@Componentpublic class TopicReceiver2 implements MessageListener {    @Override    public void onMessage(Message message) {         try {                  System.out.println("TopicReceiver2接收到消息"+((TextMessage)message).getText());              } catch (JMSException e) {                  e.printStackTrace();              }      }}

四、消息展示

1、启动activemq

浏览器输入:http://localhost:8161/admin/  默认用户名密码是admin admin  输入完成之后进入这个页面

Number Of Consumers  消费者 “这个是消费者端的消费者数量”

Number Of Pending Messages  等待消费的消息 “这个是当前未出队列的数量。可以理解为总接收数-总出队列数”
Messages Enqueued  进入队列的消息  “进入队列的总数量,包括出队列的。 这个数量只增不减”
Messages Dequeued  出了队列的消息  “可以理解为是消费这消费掉的数量”

2、启动项目

首先启动消息生产者

 然后我们打开activeMq的管理中心

3、发现未出队列数量和进入队列数量各增加到了1,这说明我们的消息正常进入了消息队列,还没有出去,下面我们启动消息消费者,项目启动完成时发现控制台已经打印出了日志。

然后我们再来看下activemq管理中心

发现消息出队列数量增加为1了 ,消息未出队数量减少为0了。说明我们服务正常

五、总结

这样就实现了消息的消费者与生产者的分离,后期我会为大家提供更好的文章,欢迎大家找茬,大家可以关注我的微信公众帐号 骑猪上树  这是我自己开发的微信机器人谢谢大家

 

这是项目的地址:https://github.com/gitChenchao/activemq

 

转载于:https://www.cnblogs.com/qizhushangshu/p/6972256.html

你可能感兴趣的文章
jmeter使用中的问题
查看>>
关于HTML+CSS3的一些笔记
查看>>
如何获取免费比特币?
查看>>
排序小结
查看>>
python 常见内置函数setattr、getattr、delattr、setitem、getitem、delitem
查看>>
使用bat脚本添加JAVA_HOME和修改PATH
查看>>
全自动备份vss和sql数据库(含源码下载)
查看>>
[转] boost undefined reference to 'pthread_create 问题
查看>>
如何不显示地图就获取位置数据?
查看>>
读取指定文件夹限定文件
查看>>
EF 更新条目时出错。有关详细信息,请参见内部异常。
查看>>
TIDB介绍 新数据库趋势
查看>>
ArcGIS For Flex学习之Mapping---Map Extent and Mouse Coordinates
查看>>
libgdx的菜单配置,以及json文件的结构
查看>>
Git基础知识与常用命令
查看>>
Set和Map数据
查看>>
关于Patter类和Match类
查看>>
[改善Java代码]生成子列表后不要再操作原列表
查看>>
9套Android实战经典项目资料分享给大家
查看>>
第2个程序:用C语言实现点亮一盏led
查看>>