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,可以不断发消息,队列堆积后,可以从管理控制台看到:

猜你喜欢

转载自blog.csdn.net/weixin_42858906/article/details/83477048
今日推荐