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 一.资料文档 二.开发语言 三.支持的协议 四.消息存储 五.消息事务 六.负载均衡 七.集群 ...
随机推荐
- SQL允许远程访问
1.打开sqlserver对象资源管理器 右键 方面 常规 服务器配置 RemoteAccessEnabled true RemoteDacEnabled true 2.打开SQL SERVER管理 ...
- WordPress 主题开发 - (二) 理解主题 待翻译
What is “Theme Sense”? What is “Theme Sense”? Theme Sense is an intuitive understanding of WordPress ...
- 【Delphi】圆角窗体
procedure TForm1.FormCreate(Sender: TObject); var hr :thandle; begin hr:=createroundrectrgn(1,1,widt ...
- How to change Form & Property & Report font for current User [AX2012]
对于我们开发人员来说,系统默认的字体,本人实在不喜欢,尤其是属性字体[太小,太细,根本看不清],每次做一个新项目[AX2012]第一件事就是更改字体. 由于AX2012没有像AX2009那样,可以工具 ...
- SQLIO Disk Subsystem Benchmark Tool
C:\Program Files (x86)\SQLIO>sqlio -? sqlio v1.5.SG -?: invalid option Usage: sqlio [options] [&l ...
- PAT乙级真题1008. 数组元素循环右移问题 (20)
原题: 1008. 数组元素循环右移问题 (20) 时间限制400 ms内存限制65536 kB 一个数组A中存有N(N>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(M&g ...
- IOS 控件的生命周期
ViewController的生命周期包括: Initialize ViewDidLoad ViewWillAppear ViewDidAppear ViewWillDisappear ViewDid ...
- (C学习基础)一,CMD的使用
以后考研要考数据结构,所以系统的整理一下C学习笔记.这里开发用VS2013 CMD资料在这里下载 首先就是DOS系统的CMD的使用,是不是觉得会命令行语句的人特别牛呢,有时候使用命令行总是事半功倍, ...
- Android ADB 端口占用问题解决方案
问题描述: The connection to adb is down, and a severe error has occured. You must restart adb and Eclips ...
- html+css学习笔记 2[标签]
img标签/a标签 <img src="图片地址" alt="图片名"/> 图片(单标签)alt属性 是图片名字,是给百度搜索引擎抓取使用: ...