activeMQ开发笔记,activeMQy与Spring框架集成
activeMQ开发笔记,activeMQy与Spring框架集成
2017年01月16日 16:00:27 阿星777 阅读数:3150 标签: java消息队列 更多
个人分类: java
MQ开发其实很简单:
本文以最新版本的ActiveMQ为例子,介绍了安装和开发第一个MQ程序。
准备环境,JDK8,activeMQ 5.14.3,WIN7测试环境,Spring 4.3.4
首先是安装 :
安装MQ非常简单,下载链接:https://activemq.apache.org/download.html
下载完apache-activemq-5.14.3-bin.zip,解压缩放在D:\greenPro\mq514下
如果,系统的java环境没有配置错误,执行D:\greenPro\mq514\bin\win64下的
activemq.bat
即可启动成功。
启动完成后,可以本地访问mq控制台:
http://localhost:8161/
默认用户名和密码:
admin/admin
点击:Manage ActiveMQ broker就可以进入队列配置界面:
这里我定义了一个自己的队列myQuery1,便于后面开发和测试:
开发参考源码和配置见这篇文章:http://blog.csdn.net/dlf123321/article/details/51615386
为了简化原来程序,做了以下改进,去掉了无用的邮件发送类和线程池,将客户端和服务端代码整合在一起了。
修改了pom.xml更新为最新的依赖包,去掉了一些无用的包。
最新源码上传于我的空间:
如果要只发送不接收,则可以注释掉spring-mq.xml最后几行,禁止ConsumerSessionAwareMessageListener启动,测试消息堆积于队列中的情况。
<?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"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd"
default-autowire="byName" default-lazy-init="false">
<!-- 基于Dubbo的分布式系统架构****,吴水成,[email protected],学习交流QQ群:367211134 -->
<!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供 -->
<bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
<!-- ActiveMQ服务地址 -->
<property name="brokerURL" value="${mq.brokerURL}" />
<property name="userName" value="${mq.userName}"></property>
<property name="password" value="${mq.password}"></property>
</bean>
<!--
ActiveMQ为我们提供了一个PooledConnectionFactory,通过往里面注入一个ActiveMQConnectionFactory
可以用来将Connection、Session和MessageProducer池化,这样可以大大的减少我们的资源消耗。
要依赖于 activemq-pool包
-->
<bean id="pooledConnectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory">
<property name="connectionFactory" ref="targetConnectionFactory" />
<property name="maxConnections" value="${mq.pool.maxConnections}" />
</bean>
<!-- Spring用于管理真正的ConnectionFactory的ConnectionFactory -->
<bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
<!-- 目标ConnectionFactory对应真实的可以产生JMS Connection的ConnectionFactory -->
<property name="targetConnectionFactory" ref="pooledConnectionFactory" />
</bean>
<!-- Spring提供的JMS工具类,它可以进行消息发送、接收等 -->
<!-- 队列模板 -->
<bean id="activeMqJmsTemplate" class="org.springframework.jms.core.JmsTemplate">
<!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->
<property name="connectionFactory" ref="connectionFactory"/>
<property name="defaultDestinationName" value="${queueName}"></property>
</bean>
<!--这个是sessionAwareQueue目的地 -->
<bean id="sessionAwareQueue" class="org.apache.activemq.command.ActiveMQQueue">
<constructor-arg>
<value>${queueName}</value>
</constructor-arg>
</bean>
<!-- 可以获取session的MessageListener -->
<!-- <bean id="consumerSessionAwareMessageListener" class="wusc.edu.demo.mqtest.listener.ConsumerSessionAwareMessageListener"></bean> -->
<!-- <bean id="sessionAwareListenerContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer"> -->
<!-- <property name="connectionFactory" ref="connectionFactory" /> -->
<!-- <property name="destination" ref="sessionAwareQueue" /> -->
<!-- <property name="messageListener" ref="consumerSessionAwareMessageListener" /> -->
<!-- </bean> -->
</beans>
红字部分为注释掉的内容。
反复运行MQProducerTest,可以不断发消息,队列堆积后,可以从管理控制台看到: