ActiveMQ JMS实现消息发送
一、创建配置消息发送接收目的地、 ActiveMQ中间件地址
- JMS_BROKER_URL=failover://(tcp://192.168.1.231:61616)
- QUEUE_BUSP_TP_SMS_MESSAGE=busp.tp.sms.message
二、创建消息生产者配置
- <?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:tx="http://www.springframework.org/schema/tx"
- xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:aop="http://www.springframework.org/schema/aop"
- xmlns:jee="http://www.springframework.org/schema/jee"
- xsi:schemaLocation="
- http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
- http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd
- http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.1.xsd
- http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-2.5.xsd">
- <!-- load config file -->
- <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
- <property name="ignoreUnresolvablePlaceholders" value="true" />
- <property name="locations">
- <list>
- <value>classpath:property/sms-jms.properties</value>
- </list>
- </property>
- </bean>
- <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供-->
- <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
- <property name="brokerURL" value="${JMS_BROKER_URL}"/>
- </bean>
- <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
- <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
- <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
- <property name="targetConnectionFactory" ref="targetConnectionFactory"/>
- </bean>
- <!-- Spring提供的JMS工具类,它可以进行消息发送、接收等 -->
- <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
- <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->
- <property name="connectionFactory" ref="connectionFactory"/>
- </bean>
- <!-- 发送资金流水-->
- <bean id="sendMessageDestination" class="org.apache.activemq.command.ActiveMQQueue">
- <constructor-arg>
- <value>${QUEUE_BUSP_TP_SMS_MESSAGE}</value>
- </constructor-arg>
- </bean>
- </beans>
三、创建生产者并发送消息
- package com.busp.tp.sms.sender;
- import javax.jms.Destination;
- import javax.jms.JMSException;
- import javax.jms.Message;
- import javax.jms.Session;
- import org.apache.log4j.Logger;
- import org.springframework.context.support.ClassPathXmlApplicationContext;
- import org.springframework.jms.core.JmsTemplate;
- import org.springframework.jms.core.MessageCreator;
- import com.busp.tp.sms.common.SMSMsg;
- /**
- * @ClassName: PushJMSSender
- * @version 1.0
- * @Desc: 向jms发送消息
- * @date 2016年4月21日下午6:01:26
- * @history v1.0
- *
- */
- @SuppressWarnings("resource")
- public class SMSJMSSender {
- // 日志文件
- private static Logger logger = Logger.getLogger(SMSJMSSender.class);
- // jms template
- private static JmsTemplate jmsTemplate;
- // 目标地址
- private static Destination sendMessageDestination;
- static{
- ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:sms-jms-sender.xml");
- ctx.registerShutdownHook();
- sendMessageDestination = (Destination) ctx.getBean("sendMessageDestination");
- jmsTemplate = (JmsTemplate) ctx.getBean("jmsTemplate");
- }
- /**
- *
- * 描述:向JMS推送消息(批量)
- * @date 2016年4月21日下午6:31:48
- * @param pushMsg
- */
- public static void sendJMSMessage(SMSMsg smsMsg){
- try {
- final String result = smsMsg.toJSONString();
- logger.info("向JMS推送消息:" + result);
- jmsTemplate.send(sendMessageDestination, new MessageCreator() {
- public Message createMessage(Session session)
- throws JMSException {
- return session.createTextMessage(result);
- }
- });
- } catch (Exception e) {
- logger.error("向JMS推送消息发生了异常",e);
- }
- }
- }
四、创建接收者配置
- <?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:aop="http://www.springframework.org/schema/aop"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xmlns:context="http://www.springframework.org/schema/context"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"
- default-lazy-init="false">
- <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
- <property name="ignoreUnresolvablePlaceholders" value="true" />
- <property name="locations">
- <list>
- <value>classpath:property/sms-jms.properties</value>
- </list>
- </property>
- </bean>
- <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供-->
- <bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
- <property name="brokerURL" value="${JMS_BROKER_URL}"/>
- </bean>
- <!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
- <bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
- <!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
- <property name="targetConnectionFactory" ref="targetConnectionFactory"/>
- </bean>
- <!-- ################################### 监听放款信息 Start #####################################-->
- <bean id="smsMessageQueueDestination" class="org.apache.activemq.command.ActiveMQQueue">
- <constructor-arg>
- <value>${QUEUE_BUSP_TP_SMS_MESSAGE}</value>
- </constructor-arg>
- </bean>
- <bean id="smsMessageListener" class="com.busp.tp.sms.listener.SMSMessagelListener"/>
- <bean id="smsMessageContainer"
- class="org.springframework.jms.listener.DefaultMessageListenerContainer">
- <property name="connectionFactory" ref="targetConnectionFactory" />
- <property name="destination" ref="smsMessageQueueDestination" />
- <property name="messageListener" ref="smsMessageListener" />
- </bean>
- <!-- ################################### 监听放款信息 End #############################
- </beans>
五、接受者接收消息
- package com.busp.tp.sms.listener;
- import javax.annotation.Resource;
- import javax.jms.JMSException;
- import javax.jms.Message;
- import javax.jms.MessageListener;
- import javax.jms.TextMessage;
- import org.apache.log4j.Logger;
- import com.busp.common.util.string.StringUtil;
- import com.busp.tp.sms.handler.SMSHandler;
- /**
- * @ClassName: PushMessageListener
- * @version 1.0
- * @Desc: TODO
- * @date 2016年4月21日下午4:19:18
- * @history v1.0
- *
- */
- public class SMSMessagelListener implements MessageListener{
- // 日志文件
- private Logger logger = Logger.getLogger(SMSMessagelListener.class);
- @Resource
- private SMSHandler yxtSMSHandler;
- //@Resource
- //private PushMsgHandler androidPushMsgHandler;
- @Override
- public void onMessage(Message message) {
- try {
- TextMessage text = (TextMessage) message;
- final String value = text.getText();
- logger.info("接收到客户端发来的消息:"+ value);
- } catch (JMSException e) {
- logger.error("",e);
- }
- }
- }
ActiveMQ JMS实现消息发送的更多相关文章
- ActiveMQ点对点的消息发送案例
公司最近会用MQ对某些业务进行处理,所以,这次我下载了apache-activemq-5.12.0-bin把玩下. 基于练习方便需要,使用Windows的版本. 参考的优秀文章: activemq的几 ...
- ActiveMQ教程(消息发送和接受)
一 环境的搭建 version为你的版本号 如果你是普通的项目的话,创建一个lib文件夹,导入相应的jar包到你的lib中,jar包为:activemq-all-{version}.jar.log4j ...
- JMS异步消息机制
企业消息系统 Java Message Service 是由 Sun Microsystems 开发的,它为 Java 程序提供一种访问 企业消息系统 的方法.在讨论 JMS 之前,我们分来析一下企业 ...
- ActiveMQ学习笔记(5)——使用Spring JMS收发消息
摘要 ActiveMQ学习笔记(四)http://my.oschina.net/xiaoxishan/blog/380446 中记录了如何使用原生的方式从ActiveMQ中收发消息.可以看出,每次 ...
- activemq安装与简单消息发送接收实例
安装环境:Activemq5.11.1, jdk1.7(activemq5.11.1版本需要jdk升级到1.7),虚拟机: 192.168.147.131 [root@localhost softwa ...
- 消息中间件--ActiveMQ&JMS消息服务
### 消息中间件 ### ---------- **消息中间件** 1. 消息中间件的概述 2. 消息中间件的应用场景 * 异步处理 * 应用解耦 * 流量削峰 * 消息通信 --------- ...
- ActiveMQ(2)---ActiveMQ原理分析之消息发送
持久化消息和非持久化消息的发送策略 消息同步发送和异步发送 ActiveMQ支持同步.异步两种发送模式将消息发送到broker上.同步发送过程中,发送者发送一条消息会阻塞直到broker反馈一个确认消 ...
- ActiveMQ安装与入门程序 & JMS的消息结构
1.Activemq安装 直接到官网下载:记住apache的官网是域名反过来,比如我们找activemq就是activemq.apache.org. 最新版本要求最低的JDK是8,所以最好在电脑装多个 ...
- 【ActiveMQ】ActiveMQ在Windows的安装,以及点对点的消息发送案例
公司最近会用MQ对某些业务进行处理,所以,这次我下载了apache-activemq-5.12.0-bin把玩下. 基于练习方便需要,使用Windows的版本. 参考的优秀文章: activemq的几 ...
随机推荐
- 【BZOJ4027】[HEOI2015]兔子与樱花 贪心
[BZOJ4027][HEOI2015]兔子与樱花 Description 很久很久之前,森林里住着一群兔子.有一天,兔子们突然决定要去看樱花.兔子们所在森林里的樱花树很特殊.樱花树由n个树枝分叉点组 ...
- JavaWeb中servlet读取配置文件的方式
我们在JavaWeb中常常要涉及到一些文件的操作,比如读取配置文件,下载图片等等操作.那我们能不能采用我们以前在Java工程中读取文件的方式呢?废话不多说我们来看看下我们以前在Java工程中读取文件是 ...
- mysqldump迁移说明
使用mysqldump导出数据, 数据包含单行insert,带字段值 #使用mysqldump备份数据到文件, 主要在每个分片的主上面进行备份,确保数据是最新的. mysqldump -h192. - ...
- Python2 显示 unicode
用户想要看的是 u'中文' 而不是 u'\u4e2d\u6587',但是在 Python2 中有时并不能实现. 转译 转义字符是这样一个字符,标志着在一个字符序列中出现在它之后的后续几个字符采取一种替 ...
- 7.Insert Methods-官方文档摘录
总结 列举insert插入方法 MongoDB provides the following methods for inserting documents into a collection: db ...
- gevent For the Working Python Developer
Gevent指南 gevent程序员指南 由Gevent社区编写 gevent是一个基于libev的并发库.它为各种并发和网络相关的任务提供了整洁的API. 介绍 贡献者 核心部分 Greenle ...
- 我的Android进阶之旅------>解决Error:Unable to find method 'org.gradle.api.internal.project.ProjectInternal.g
错误描述 今天在Github上面下载了一份代码,然后导入到Android Studio中直接报了如下图所示的错误: 错误描述如下: Error: Unable to find method 'org. ...
- PHP memcache的使用教程
(结尾附:完整版资源下载) 首先,为什么要用memcached?如果你看过InnoDB的一些书籍,你应该知道在存储引擎那一层是由一个内存池的.而在内存池中 又有一个缓冲池.而缓冲池就会缓冲查找的数据, ...
- django 通过orm操作数据库
Django Model 每一个Django Model都继承自django.db.models.Model 在Model当中每一个属性attribute都代表一个database field 通过D ...
- 中文Appium API 文档
该文档是Testerhome官方翻译的源地址:https://github.com/appium/appium/tree/master/docs/cn官方网站上的:http://appium.io/s ...