学习淘淘商城第六十一课(Activemq与Spring整合接收消息)

来源:互联网 发布:淘宝电话卡为什么便宜 编辑:程序博客网 时间:2024/05/21 22:32

       我们测试接收消息换个工程来测试,就用taotao-search-service工程,要用这个工程来接收ActiveMQ消息就要先添加对activemq-all的依赖。如下图所示。


         添加的依赖如下

<!-- activemq组件 -->  <dependency><groupId>org.apache.activemq</groupId><artifactId>activemq-all</artifactId></dependency>

        下面我们新建一个监听器类,该类继承自MessageListener,如下图所示。


       MyMessageListener类代码如下:

package com.taotao.search.listener;import javax.jms.JMSException;import javax.jms.Message;import javax.jms.MessageListener;import javax.jms.TextMessage;/** * 接收ActiveMQ发送的消息 * @author wanghaijie * */public class MyMessageListener implements MessageListener {@Overridepublic void onMessage(Message message) {try {TextMessage textMessage = (TextMessage)message;String text = textMessage.getText();System.out.println(text);} catch (JMSException e) {e.printStackTrace();}}}

       下面我们需要新建一个activemq的配置文件,如下图所示。


       applicationContext-activemq.xml文件的内容如下:

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.2.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsdhttp://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-4.2.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.2.xsdhttp://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.2.xsd"><!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供 --><bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory"><property name="brokerURL" value="tcp://192.168.156.30:61616" /></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="queueDestination" class="org.apache.activemq.command.ActiveMQQueue"><constructor-arg value="spring-queue"/></bean><!--这个是主题目的地,一对多的 --><bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic"><constructor-arg value="topic" /></bean><!-- 接收消息 --><!-- 配置监听器 --><bean id="messageListener" class="com.taotao.search.listener.MyMessageListener"/><!-- 消息监听容器 --><bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">    <property name="connectionFactory" ref="connectionFactory"/>    <property name="destination" ref="queueDestination"/>    <property name="messageListener" ref="messageListener"/></bean></beans>

         最后新建一个包和一个测试类,如下图所示。


         测试类代码如下:

package com.taotao.activemq;import java.io.IOException;import org.junit.Test;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;public class TestSpringActiveMQ {   @Testpublic void testActiveMQConsumer() throws IOException{//初始化Spring容器ApplicationContext context = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-activemq.xml");//等待接收消息System.in.read();}}

       下面我们便来运行上面的测试方法,在控制台会看到接收到了一条activemq消息,这是上节课我们发送的activemq消息,由于当时没有消费者,所以这条消息一直留到现在。现在我们有了消费者,自然就消费了那条没有被消费的消息。我们还可以再发送几条activemq消息看看这个控制台是否都能接收的了。


        我们再用JmsTemplate来发送一条消息试试,结果如下图所示,可以正常接收到。如果不想让测试类继续接收消息的话,可以在控制台直接敲回车即可。


0 0
原创粉丝点击