Spring + JMS + ActiveMQ实现简单的消息队列(监听器异步实现)
首先声明:以下内容均是在网上找别人的博客综合学习而成的,可能会发现某些代码与其他博主的相同,由于参考的文章比较多,这里对你们表示感谢,就不一一列举,如果有侵权的地方,请通知我,我可以把该文章删除。
1、jms-xml Spring配置文件
- <?xml version="1.0" encoding="UTF-8"?>
- <beans
- xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:p="http://www.springframework.org/schema/p"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
- <bean id = "connectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
- <property name = "brokerURL" value = "tcp://localhost:61616"/>
- </bean>
- <bean id = "topicDestination" class="org.apache.activemq.command.ActiveMQTopic"
- autowire="constructor">
- <constructor-arg value="com.spring.xkey.jms.topic"/>
- </bean>
- <bean id="sendMessage" class="com.spring.xkey.jms.SendMessage">
- <property name="username" value="xkey"/>
- <property name="password" value="1234567890"/>
- </bean>
- <bean id = "jmsMessageConverter" class="com.spring.xkey.jms.JmsMessageConverter">
- <property name="sendMessage" ref="sendMessage"/>
- </bean>
- <!-- 创建JMS发送信息的模板的对象 -->
- <bean id = "jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
- <property name="connectionFactory" ref="connectionFactory"/>
- <!--property name="defaultDestination" ref="topicDestination"/-->
- <property name="receiveTimeout" value="6000"/>
- <property name="messageConverter" ref="jmsMessageConverter"/>
- </bean>
- <bean id = "jmsMessageListener" class="com.spring.xkey.jms.JmsMessageListener">
- </bean>
- <bean id = "publisher" class="com.spring.xkey.jms.Publisher">
- <property name="jmsTemplate" ref="jmsTemplate"/>
- <property name="destinations" ref="topicDestination" />
- <property name="sendMessage" ref="sendMessage"/>
- </bean>
- <bean id = "consumer" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
- <property name="connectionFactory" ref="connectionFactory"/>
- <property name="destination" ref="topicDestination" />
- <property name="messageListener" ref="jmsMessageListener" />
- </bean>
- </beans>
2、Listener代码
- package com.spring.xkey.jms;
- import java.util.Date;
- import javax.jms.JMSException;
- import javax.jms.Message;
- import javax.jms.MessageListener;
- import org.apache.activemq.command.ActiveMQMapMessage;
- public class JmsMessageListener implements MessageListener {
- public void onMessage(Message message) {
- ActiveMQMapMessage msg = null;
- //System.out.println("ONMessage-----------------" + message.toString());
- try {
- if (message instanceof ActiveMQMapMessage) {
- msg = (ActiveMQMapMessage) message;
- String username = msg.getString("username");
- String password = msg.getString("password");
- System.out.println("Message::: "+username+", "+password);
- // msg = (ActiveMQMapMessage) message;
- // String sentDate = msg.getString("date");
- // String reMessage = msg.getString("message");
- // int sentCount = msg.getInt("count");
- // System.out
- // .println("-------------New Message Arrival-----------"
- // + new Date());
- // System.out.println("It's " + sentCount + " time From Darcy: "
- // + reMessage + " ---Send time :" + sentDate);
- }
- } catch (JMSException e) {
- System.out.println("JMSException in onMessage(): " + e.toString());
- } catch (Throwable t) {
- System.out.println("Exception in onMessage():" + t.getMessage());
- }
- }
- }
3、Converter代码
- package com.spring.xkey.jms;
- import javax.jms.JMSException;
- import javax.jms.MapMessage;
- import javax.jms.Message;
- import javax.jms.Session;
- import org.springframework.jms.support.converter.MessageConversionException;
- import org.springframework.jms.support.converter.MessageConverter;
- public class JmsMessageConverter implements MessageConverter{
- private SendMessage sendMessage;
- public void setSendMessage(SendMessage sendMsg){
- this.sendMessage = sendMsg;
- }
- public Object fromMessage(Message message) throws JMSException,
- MessageConversionException {
- // TODO Auto-generated method stub
- MapMessage mapmessage= (MapMessage)message;
- this.sendMessage.setUsername(mapmessage.getString("username"));
- this.sendMessage.setPassword(mapmessage.getString("password"));
- System.out.println("First");
- return sendMessage;
- }
- public Message toMessage(Object arg0, Session session) throws JMSException,
- MessageConversionException {
- // TODO Auto-generated method stub
- this.sendMessage = (SendMessage)arg0;
- MapMessage mapmessage= (MapMessage) session.createMapMessage();
- mapmessage.setString("username", this.sendMessage.getUsername());
- mapmessage.setString("password", this.sendMessage.getPassword());
- System.out.println("Second");
- return mapmessage;
- }
- }
4、Publisher代码
- package com.spring.xkey.jms;
- import java.util.Scanner;
- import javax.jms.Destination;
- import org.springframework.jms.core.JmsTemplate;
- public class Publisher {
- private JmsTemplate template;
- private Destination[] destinations;
- private SendMessage sendMessage;
- public void chart()
- {
- boolean chart = true;
- int count = 0;
- while(chart)
- {
- count ++;
- Scanner cin=new Scanner(System.in);
- System.out.println("输入聊天内容,输入N停止聊天");
- String text=cin.nextLine();
- if(text.equals("N"))
- {
- chart = false;
- }
- System.out.println("我:"+text);
- sendChartMessage(count,text);
- }
- }
- public void sendMsgCon(){
- Scanner cin=new Scanner(System.in);
- String username = cin.nextLine();
- String password = cin.nextLine();
- this.sendMessage.setUsername(username);
- this.sendMessage.setPassword(password);
- sendConvertor(this.sendMessage);
- }
- public void sendConvertor(SendMessage sendMsg){
- template.convertAndSend(destinations[0],sendMsg);
- }
- protected void sendChartMessage(int count , String strMessage)
- {
- MyMessageCreator creator = new MyMessageCreator(count,strMessage);
- template.send(destinations[0], creator);
- }
- public JmsTemplate getJmsTemplate() {
- return template;
- }
- public void setJmsTemplate(JmsTemplate template) {
- this.template = template;
- }
- public Destination[] getDestinations() {
- return destinations;
- }
- public void setDestinations(Destination[] destinations) {
- this.destinations = destinations;
- }
- public void setSendMessage(SendMessage sendMsg){
- this.sendMessage = sendMsg;
- }
- public SendMessage getSendMessage(){
- return this.sendMessage;
- }
- }
5、SendMessage代码
- package com.spring.xkey.jms;
- public class SendMessage {
- private String username;
- private String password;
- public void setUsername(String user){
- this.username = user;
- }
- public void setPassword(String pass){
- this.password = pass;
- }
- public String getUsername(){
- return this.username;
- }
- public String getPassword(){
- return this.password;
- }
- }
6、Test类
- package com.spring.xkey.jms;
- import javax.jms.JMSException;
- import org.springframework.context.ApplicationContext;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import org.springframework.jms.listener.DefaultMessageListenerContainer;
- public class Test {
- /**
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- ApplicationContext context =
- new ClassPathXmlApplicationContext("jms.xml");
- /**Sender sender = (Sender)context.getBean("sender");
- sender.SendInfo();
- Receiver receiver = (Receiver)context.getBean("receiver");
- try {
- System.out.println(receiver.receiverInfo());
- } catch (JMSException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }*/
- Publisher pub = (Publisher)context.getBean("publisher");
- DefaultMessageListenerContainer consumer =
- (DefaultMessageListenerContainer)context.getBean("consumer");
- consumer.start();
- pub.sendMsgCon();
- //pub.chart();
- }
- }
Spring + JMS + ActiveMQ实现简单的消息队列(监听器异步实现)的更多相关文章
- 深入剖析 RabbitMQ —— Spring 框架下实现 AMQP 高级消息队列协议
前言 消息队列在现今数据量超大,并发量超高的系统中是十分常用的.本文将会对现时最常用到的几款消息队列框架 ActiveMQ.RabbitMQ.Kafka 进行分析对比.详细介绍 RabbitMQ 在 ...
- Spring JMS ActiveMQ整合(转)
转载自:http://my.oschina.net/xiaoxishan/blog/381209#comment-list ActiveMQ学习笔记(四)http://my.oschina.net/x ...
- Java编程的逻辑 (61) - 内存映射文件及其应用 - 实现一个简单的消息队列
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...
- SpringBoot使用JMS(activeMQ)的两种方式 队列消息、订阅/发布
刚好最近同事问我activemq的问题刚接触所以分不清,前段时间刚好项目中有用到,所以稍微整理了一下,仅用于使用 1.下载ActiveMQ 地址:http://activemq.apache.org/ ...
- spring与activemq(三种消息监听方式)
1.3 消息监听器MessageListener 在Spring整合JMS的应用中我们在定义消息监听器的时候一共可以定义三种类型的消息监听器,分别是MessageListener.Sessio ...
- Spring Boot:使用Rabbit MQ消息队列
综合概述 消息队列 消息队列就是一个消息的链表,可以把消息看作一个记录,具有特定的格式以及特定的优先级.对消息队列有写权限的进程可以向消息队列中按照一定的规则添加新消息,对消息队列有读权限的进程则可以 ...
- MQ选型对比ActiveMQ,RabbitMQ,RocketMQ,Kafka 消息队列框架选哪个?
最近研究消息队列,发现好几个框架,搜罗一下进行对比,说一下选型说明: 1)中小型软件公司,建议选RabbitMQ.一方面,erlang语言天生具备高并发的特性,而且他的管理界面用起来十分方便.不考虑r ...
- Spring AMQP + Rabbit 配置多数据源消息队列
一般在稍微大一点的项目中,需要配置多个数据库数据源,最简单的方式是用 Spring 来实现,只需要继承 AbstractRoutingDataSource 类,实现 determineCurrentL ...
- 17 个方面,综合对比 Kafka、RabbitMQ、RocketMQ、ActiveMQ 四个分布式消息队列
原文:https://mp.weixin.qq.com/s/lpsQ3dEZHma9H0V_mcxuTw 一.资料文档 二.开发语言 三.支持的协议 四.消息存储 五.消息事务 六.负载均衡 七.集群 ...
随机推荐
- R简易入门(二)
本文内容来源:https://www.dataquest.io/mission/128/working-with-data-frames 本文摘要:简单介绍一下用R处理数据 原始数据展示(这是一份 ...
- 【面试虐菜】—— JAVA面试题(3)
1 throws与throw的区别 解析:throws和throw是异常处理时两个常见的关键字,初级程序员常常容易正确理解throw和throws的作用和区别,说明已经能比较深入理解异常处理.Thro ...
- openerp 经典收藏 Openerp开发进销存系统完毕总结(转载)
原文地址:http://blog.csdn.net/heartrude/article/details/9142463 Openerp开发进销存系统完毕总结 分类: 代码历程 OpenERP 工程思想 ...
- mac os使用homebrew来管理后台服务
在linux下我们经常通过 service 或者 /etc/init.d/来管理我们的后台服务软件,并使用包管理器安装这些软件. 在mac下有homebrew这个好用的工具来安装软件,但是一直没有找到 ...
- YARN环境搭建 之 一:CentOS7.0系统配置
一.我缘何选择CentOS7.0 14年7月7日17:39:42发布了CentOS 7.0.1406正式版,我曾使用过多款Linux,对于Hadoop2.X/YARN的环境配置缘何选择CentOS7. ...
- range,shuffle,str_shuffle
print_r(range(1,20)); 输出,range产生 Array( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 ...
- 【BZOJ 1068】[SCOI2007]压缩
Description 给 一个由小写字母组成的字符串,我们可以用一种简单的方法来压缩其中的重复信息.压缩后的字符串除了小写字母外还可以(但不必)包含大写字母R与M,其中M 标记重复串的开始,R重复从 ...
- Android SDK Android NDK 官方下载地址
Android NDK r6b Windows http://dl.google.com/android/ndk/android-ndk-r6b-windows.zip Mac OS X(intel) ...
- C# XML - XmlNode and XmlAttribute
public static string TestXML(string path) { XmlDocument doc = new XmlDocument(); doc.Load(path); Xml ...
- win8安装新字体
http://jingyan.baidu.com/article/e3c78d640a7ab33c4c85f52d.html