- 浏览: 691678 次
- 性别:
- 来自: 北京
博客专栏
-
读金庸故事,品程序人生
浏览量:47234
文章分类
最新评论
-
hty881008:
LZ,你的json返回是怎么出来的,我的怎么是No messa ...
使用CXF暴露您的REST服务 -
jxFY:
赞
Apache的对象池化工具commons-pool -
wangyudong:
新版本的Wisdom RESTClient地址https:// ...
使用CXF暴露您的REST服务 -
wangyudong:
由CXF实现的微服务需要有比较好的工具去测试RESTful A ...
使用CXF暴露您的REST服务 -
spring_springdata:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
Maven3实战笔记01环境配置与使用入门
1. 前言
基于JMS标准的消息中间件实现的产品有很多,JBossMQ、ActiveMQ、OpenMQ、OpenJMS等等,最常用的还是apache的ActiveMQ。有时也使用Sun的OpenMQ。在官网http://mq.java.net/处可以下载。Open Message Queue是Sun Java System Message Queue的一个开源版本。Open message queue是一个企业级,可升级,非常成熟的消息服务器。它为面向消息的系统集成提供一套完整的JMS(Java Message Service )实现。由于Open MQ源自Sun的Java Message Queue,所以其具有Java System Message Queue拥有的所有特性,功能和性能。
2. 环境配置
下载后将相关的jar拷贝到项目的classpath下面。笔者在此为了安全起见,引入了很多jar包,将语言包都引入了。各位读者可以因地制宜。
以下是引入jar包的列表
3. 之后项目加入Spring的相关jar包。lib/openmqjar/common-message.jar
lib/openmqjar/fscontext.jar
lib/openmqjar/grizzly.jar
lib/openmqjar/imq_de.jar
lib/openmqjar/imq_es.jar
lib/openmqjar/imq_fr.jar
lib/openmqjar/imq_it.jar
lib/openmqjar/imq_ja.jar
lib/openmqjar/imq_ko.jar
lib/openmqjar/imq_pt_BR.jar
lib/openmqjar/imq_zh_CN.jar
lib/openmqjar/imq_zh_TW.jar
lib/openmqjar/imq.jar
lib/openmqjar/imqadmin.jar
lib/openmqjar/imqbridgemgr.jar
lib/openmqjar/imqbroker.jar
lib/openmqjar/imqjmsbridge.jar
lib/openmqjar/imqjmsra.rar
lib/openmqjar/imqjmx_de.jar
lib/openmqjar/imqjmx_es.jar
lib/openmqjar/imqjmx_fr.jar
lib/openmqjar/imqjmx_it.jar
lib/openmqjar/imqjmx_ja.jar
lib/openmqjar/imqjmx_ko.jar
lib/openmqjar/imqjmx_pt_BR.jar
lib/openmqjar/imqjmx_zh_CN.jar
lib/openmqjar/imqjmx_zh_TW.jar
lib/openmqjar/imqjmx.jar
lib/openmqjar/imql10n_server_de.jar
lib/openmqjar/imql10n_server_es.jar
lib/openmqjar/imql10n_server_fr.jar
lib/openmqjar/imql10n_server_it.jar
lib/openmqjar/imql10n_server_ja.jar
lib/openmqjar/imql10n_server_ko.jar
lib/openmqjar/imql10n_server_pt_BR.jar
lib/openmqjar/imql10n_server_zh_CN.jar
lib/openmqjar/imql10n_server_zh_TW.jar
lib/openmqjar/imqservlet.jar
lib/openmqjar/imqstomp.jar
lib/openmqjar/imqutil.jar
lib/openmqjar/imqxm.jar
lib/openmqjar/jaxm-api.jar
lib/openmqjar/jhall.jar
lib/openmqjar/jms.jar
lib/openmqjar/jta.jar
lib/openmqjar/protobuf-2.3.0.jar
增加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: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-2.5.xsd" default-autowire="byName"> <!--消息连接工厂--> <bean id="connectionfactoryfactory" class="message.listener.OpenMqConnectionFactory"> <property name="properties"> <props> <prop key="imqAddressList">127.0.0.1:7676</prop> <prop key="imqDefaultUsername">admin</prop> <prop key="imqDefaultPassword">admin</prop> <prop key="imqReconnectEnabled">true</prop> <prop key="imqReconnectAttempts">3</prop> <prop key="imqReconnectInterval">5000</prop> <prop key="imqAddressListBehavior">RANDOM</prop> </props> </property> </bean> <bean id="mqConnectionFactory" factory-bean="connectionfactoryfactory" factory-method="createConnectionFactory" /> <!--设置广发消息目的--> <bean id="updateLocalRouteMap" class="com.sun.messaging.Topic"> <constructor-arg type="java.lang.String" value="mytopic" /> </bean> <bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate"> <property name="connectionFactory" ref="mqConnectionFactory" /> <property name="defaultDestination" ref="updateLocalRouteMap" /> <property name="receiveTimeout" value="20000" /> </bean> <!--消息监听器--> <bean id="messageListener1" class="org.springframework.jms.listener.adapter.MessageListenerAdapter"> <constructor-arg> <bean class="message.listener.JMSMessageListener" /> </constructor-arg> <property name="defaultListenerMethod" value="receive" /> <property name="messageConverter"> <null /> </property> </bean> <!—实际的消息监消费者配置--> <bean id="consumercontainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer"> <property name="connectionFactory" ref="mqConnectionFactory" /> <property name="destination" ref="updateLocalRouteMap" /> <property name="messageListener" ref="messageListener1" /> <property name="transactionTimeout" value="180000" /> <property name="receiveTimeout" value="180000" /> <property name="sessionTransacted" value="true" /> </bean> </beans>
4. 消息监听器
类代码如下
/** * JMS消息消费者。 * 接收JMS消息后获得router想要的消息后,调用router接口更新本地缓存 * @author liuyan * */ public class JMSMessageListener implements MessageListener { private Logger log = Logger.getLogger(JMSMessageListener.class.getName()); /** * 接收JMS消息后的业务处理 */ public void onMessage(Message message) { log.info("接收消息……"); byte[] byteMessage = JMSByteConverterUtil .ConverterMessageToBttes(message); try { log.info("将转型成实体对象……"); //…………………………………………………… } } catch (InvalidProtocolBufferException e) { log.error("JMS异常" + e.getMessage()); e.printStackTrace(); } catch (Exception e) { log.error("其他异常" + e.getMessage()); e.printStackTrace(); } } }
因为一些原因此处就不给出完整代码了~~~反正是获取一个字节流后,转成对象,直接从对象中获取想要的信息。转成对象的辅助类如下
/** * 对获得的消息对象进行转型 * @author liuyan */ public class JMSByteConverterUtil { private static Logger log = Logger.getLogger(JMSMessageListener.class .getName()); /** * 对获得的消息对象进行转型 * @param message * @return */ public static byte[] ConverterMessageToBttes(Message message) { if (message == null) { log.error("消息对象为空……"); return null; } else if (message instanceof BytesMessage) { log.debug("消息强制转型BytesMessage"); BytesMessage bytesMessage = (BytesMessage) message; byte[] messageBytes; try { log.debug("建立空的消息二进制数组"); messageBytes = new byte[(int) bytesMessage.getBodyLength()]; log.debug("往二进制数组中写进二进制信息"); bytesMessage.readBytes(messageBytes); log.debug("messageBytes.length=" + messageBytes.length); return messageBytes; } catch (JMSException e) { log.error("JMS错误:" + e.getMessage()); e.printStackTrace(); return null; } }else{ log.error("消息对象不能正确转型"); return null; } } }
5. 启动消息监听器
开启OpenMQ的服务,启动{OpenMQ_HOME}\mq\bin\下的imqcmd.exe命令
启动消息消费者很简单,代码如下
public class MessageConsumer { /** * @param args */ public static void main(String[] args) { ApplicationContext applicationContext = new ClassPathXmlApplicationContext( new String[] { "classpath:/spring/applicationContext-openmq-jms.xml" }); System.out.println(applicationContext.getId()); } }
6. 消息发送者
启动消息消费者服务后,写一个测试类测试一下消息的,代码如下
public class MessageSender { /** * @param args * @throws JMSException */ public static void main(String[] args) throws JMSException { ConnectionFactory myConnFactory; myConnFactory = new com.sun.messaging.ConnectionFactory(); myConnFactory.setProperty(ConnectionConfiguration.imqAddressList, "mq://127.0.0.1:7676"); myConnFactory.setProperty(ConnectionConfiguration.imqReconnectEnabled, "true"); Connection myConn = myConnFactory.createConnection(); myConn.start(); // Step 4: // Create a session within the connection. Session mySess = myConn.createSession(false, Session.AUTO_ACKNOWLEDGE); Topic myTopic = new com.sun.messaging.Topic("testmq");// .Queue("testmq"); MessageProducer myMsgProducer = mySess.createProducer(myTopic); ObjectMessage objectMessage = mySess.createObjectMessage(); RouterMessageBean routerMessageBean = new RouterMessageBean(); routerMessageBean.setDbName("mysql-test"); routerMessageBean.setUserName("liuyan"); routerMessageBean.setMaster(null); routerMessageBean.setSlave(null); objectMessage.setObject(routerMessageBean); BytesMessage bytesMessage = mySess.createBytesMessage(); bytesMessage.writeUTF("the message is 消息内容!"); myMsgProducer.send(bytesMessage); System.out.println("测试发送JMS消息"); mySess.close(); myConn.close(); } }
发表评论
-
Web应用单点压力测试调优-第6季-阶段性总结
2014-03-14 12:24 3254阶段性总结 <! ... -
Web应用单点压力测试调优-第5季
2014-03-13 09:32 4017各项配置: my.cnf [clien ... -
Web应用单点压力测试调优-第4季
2014-03-12 14:55 3038调整5-Tomcat的启动JVM参数 首先先启动 ... -
单点网站压力测试调优-第3季
2014-03-11 16:21 3299调整2-调整配置,数据库连接池数量 mysql ... -
Web应用单点压力测试调优-第2季
2014-03-07 16:52 8751并发1000,准备时间1s,让它产生大量的等待请求 ... -
单点网站压力测试调优-第1季
2014-03-07 10:36 3829环境介绍 虚拟机配置 ... -
编程质量提高建议总结1(持续总结)
2014-03-05 19:42 1217编程质量提高建议总结1(持续总结) 1.混淆字母要明显 ... -
关于博客文章内容显示不全的问题
2011-06-14 09:36 2268关于博客文章内容显示不全的问题,我发现有些文章显示内容不全。 ... -
Maven3实战笔记05仓库依赖解析与插件解析
2011-06-07 09:00 33671. Maven仓库依赖解析机 ... -
Apache的对象池化工具commons-pool
2011-05-16 09:21 129561. 前言 当我们的应用中创建一个十分最重量级的 ... -
要不要池化是个艰难的选择(转)-我觉得很生动就转载了下来
2011-05-05 09:50 1532转自http://www.ixpub.net/thre ... -
java.lang.IllegalStateException: STREAM错误的理解(转)
2011-05-04 18:09 13768转自http://dimple.iteye.com/blog/ ... -
Spring3配置声明式事务
2011-05-02 16:52 45031. 配置Spring3声明式事务 在Sprin ... -
Java基础复习笔记11基本排序算法
2011-04-25 13:20 20791. 排序 排序是一个历来都是很多算法家热衷的领 ... -
Java基础复习笔记08数据结构-二叉树和二叉树的遍历
2011-04-22 09:10 24721. 二叉树 一 ... -
Java基础复习笔记07数据结构-树的概述
2011-04-19 17:35 18541. 树的概念 如果线性表、栈、队列是线性结构( ... -
Java基础复习笔记06数据结构-队列
2011-04-19 17:25 16021. 队列 队列又是一种比较特殊的线性表,和栈一 ... -
Java基础复习笔记04数据结构-线性表
2011-04-15 14:14 22391. 线性表 线性表是数据结构的一种逻辑结构,其 ... -
Java基础复习笔记03面试、笔试、开发中我们不太注意的陷阱之流程控制、面向对象、异常处理
2011-04-13 09:59 21681. switch语句的用法 有人说:“笔者基础 ... -
Java基础复习笔记03面试、笔试、开发中我们不太注意的陷阱之多线程
2011-04-13 09:51 19151. 什么样的对 ...
相关推荐
你可以诞生Handler之对象来与Looper沟通,以便push新讯息到Message Queue里;或者接收Looper(从Message Queue取出)所送来的讯息。 线程A的Handler对象参考可以传递给别的线程,让别的线程B或C等能送讯息来给...
主要介绍linix下安装Sun Java System Message Queuey的注意事项,安装步骤,验证方法以及配置简单集群。
Sun Java System Message Queue
MessageQueue实战MessageQueue实战MessageQueue实战MessageQueue实战MessageQueue实战MessageQueue实战MessageQueue实战MessageQueue实战MessageQueue实战MessageQueue实战
详细描述了Android的消息处理机制,Message和MessageQueue类的详解
Message,MessageQueue,Looper,Handler详解
进程间通信之消息队列 ( message queue ) 消息队列是消息的链表,具有特定的格式,并由消息队列标识符标识. 七种进程间通信方式: 一.无名管道( pipe ) 二.有名管道( fifo ) 三.共享内存 ( shared memory ) 四....
Looper MessageQueue 源码解析,通过源码 手写一套自己的Handler。
Handler+Looper+MessageQueue
是一个快速的开源消息组件(框架),支持集群,同等网络,自动检测,TCP,SSL,广播,持久化,XA,...消息异步接受,减少软件多系统集成的耦合度。消息可靠接收,确保消息在中间件可靠保存,多个消息也可以组成原子事务。
本例子主要是发送不同的消息。然后根所ID得到指定的消息内容。
Qload Webpshere message queue, WMQ, MQ
比较了Zermoq MQTT Rabbitmq 等多种Message Queue方案
基于Websphere Message Queue 的Client通信技术,韩珊珊,翟文军,Websphere Message Queue (WMQ)是一款应用广泛的IBM的商业通讯中间件(Commercial Messaging Middleware),适用于任何需要进行网络通信的系统。...
消息队列管理器在将消息从它的源中继到它的目标时充当中间人。队列的主要目的是提供路由并保证消息的传递;如果发送消息时接收者不可用,消息队列会保留消息,直到可以成功地传递它。 “消息队列”是 Microsoft 的...
一个 windows message queue 的通讯例子,消息机制的客户端和服务器端交互通通讯。
jms资料 Message Queue 3 技术概述
可以发布或者处理一个消息或者操作一个Runnable,通过Handler发布消息,消息将只会发送到与它关联的消息队列,然也只能处理该消息队列中的消息. 3、Looper: 是Handler和消息队列之间通讯桥梁,程序组件首先通过...
本指南的目标读者为需要执行 Message Queue 管理任务的系统管理员以及应用程序 开发者。 Message Queue 管理员负责设置和管理 Message Queue 消息传送系统,尤其是该系 统的核心 Message Queue 消息服务器。