Spring整合activeMQ(1)

1.點對點模式

1.1消息的生產者

(1)創建普通的maven工程 springjms_producer,在 POM 文件中引入 SpringJms 、activeMQ 以及單元測
試相關依賴

<spring.version>4.2.4.RELEASE</spring.version>



org.springframework
spring-jms
spring.version&lt;/version&gt;&lt;/dependency&gt;&lt;dependency&gt;&lt;groupId&gt;org.springframework&lt;/groupId&gt;&lt;artifactId&gt;springtest&lt;/artifactId&gt;&lt;version&gt;{spring.version}&lt;/version&gt; &lt;/dependency&gt; &lt;dependency&gt; &lt;groupId&gt;org.springframework&lt;/groupId&gt; &lt;artifactId&gt;spring-test&lt;/artifactId&gt; &lt;version&gt;{spring.version}


junit
junit
4.9


org.apache.activemq
activemq-client
5.13.4

activemq-client這個依賴jar包我自己手打不出來,複製就可以0.0......

(2)在 src/main/resources 下創建 spring 配置文件 applicationContext-jms-producer.xml

<?xml version="1.0" encoding="UTF-8"?>

<!--剛複製後這裏會報錯,因爲我們還沒有創建"com.study.demo"包-->
<context:component-scan base-package="com.study.demo"></context:component-scan>


<!-- 真正可以產生Connection的ConnectionFactory,由對應的 JMS服務廠商提供-->
<bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
    <!--這裏的tcp連接地址根據你自己的來寫-->
    <property name="brokerURL" value="tcp://192.168.25.128: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="activeMQQueue" class="org.apache.activemq.command.ActiveMQQueue">
    <constructor-arg value="queue"/>
</bean>

我的xmlns:amq="http://activemq.apache.org/schema/core"這部分在idea中一直報紅(URI is not registered),實際上並不影響程序的運行.
如果看着比較煩人的話,當然我們也可以解決這個問題,如下圖解決方法.
配置URI報紅的解決方法
( 3 )在com.study.demo包下面創建QueueProducer生產者

package com.study.demo;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessageCreator;
import org.springframework.stereotype.Component;

import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.Session;

@Component
public class QueueProducer {
    @Autowired
    private JmsTemplate jmsTemplate;
    @Autowired
    private Destination activeMQQueue;//對應於配置文件中的隊列目的地id
    /**
     * 發送文本消息
     * @param text
     */
    public void sendTextMessage(final String text){
        jmsTemplate.send(activeMQQueue, new MessageCreator() {
            public Message createMessage(Session session) throws JMSException {
                return session.createTextMessage(text);
            }
        });
    }

}

( 4 )單元測試
在 src/test/java 創建測試類

import com.study.demo.QueueProducer;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations="classpath:applicationContext-jms-producer.xml")
public class TestQueue {
    @Autowired
    private QueueProducer queueProducer;
    @Test
    public void testSend(){
        queueProducer.sendTextMessage("SpringJms-點對點模式");
    }
}
1.2消息的消費者

( 1 )創建普通的maven工程 springjms_consumer,在 POM 文件中引入依賴,和上面一樣
(2)創建配置文件 applicationContext-jms-consumer-queue.xml

<?xml version="1.0" encoding="UTF-8"?>

<!-- 真正可以產生Connection的ConnectionFactory,由對應的 JMS服務廠商提供-->
<bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
    <property name="brokerURL" value="tcp://192.168.25.128:61616"/>
</bean>

<!-- Spring用於管理真正的ConnectionFactory的ConnectionFactory -->
<bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">
    <!-- 目標ConnectionFactory對應真實的可以產生JMS Connection的ConnectionFactory -->
    <property name="targetConnectionFactory" ref="targetConnectionFactory"/>
</bean>

<!--這個是隊列目的地,點對點的  文本信息-->
<bean id="activeMQQueue" class="org.apache.activemq.command.ActiveMQQueue">
    <!--注意這裏的value一定要和生產者的一樣,這樣才能監聽到消息-->
    <constructor-arg value="queue"/>
</bean>

<!-- 我的監聽類 -->
<bean id="myMessageListener" class="com.study.demo.MyMessageListener"></bean>


<!-- 消息監聽容器 -->
<bean class="org.springframework.jms.listener.DefaultMessageListenerContainer">
    <property name="connectionFactory" ref="connectionFactory" />
    <property name="destination" ref="activeMQQueue" />
    <property name="messageListener" ref="myMessageListener" />
</bean>

( 3 )編寫監聽類

package com.study.demo;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageListener;
import javax.jms.TextMessage;

public class MyMessageListener implements MessageListener{

    public void onMessage(Message message) {

        TextMessage textMessage = (TextMessage)message;
        try {
            System.out.println("接收到消息:"+textMessage.getText());
        } catch (JMSException e) {
            e.printStackTrace();
        }
    }

}

( 4 )單元測試

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import java.io.IOException;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:applicationContext-jms-consumer-queue.xml")
public class TestQueue {
    @Test
    public void testQueue() {
        try {
            //此處爲了方便測試,讓程序不往下面執行
            System.in.read();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

當你生產者單元測試執行了一次後,消費者也執行單元測試會看到如下的結果.
在這裏插入圖片描述
則說明消費者成功的接受到了消息.

寫到這裏爲了不讓篇幅過長,所以發佈訂閱模式下篇文章再寫.

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章