activeMQ和spring的整合

今天分享的是activemq框架和spring框架的整合使用。

(1)導入activemq的核心jar包和整合spring需要的兩個jar包 context-support和jms.jar(使用spring的版本是4.2.7 activemq的版本是5.11.2)

<!--鎖定版本號-->
<properties>
  <spring.version>4.2.4.RELEASE</spring.version>
  <activemq.version>5.11.2</activemq.version>
</properties>

<!--添加依賴-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jms</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
</dependency>
<dependency>
  <groupId>org.apache.activemq</groupId>
  <artifactId>activemq-all</artifactId>
</dependency>

(2)activemq整合spring,首先需要配置connectionFactory

<?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.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd
http://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.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.2.xsd"&gt;

&lt;!-- 真正可以產生Connection的ConnectionFactory,由對應的 JMS服務廠商提供 --&gt;
&lt;bean id="targetConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory"&gt;
    &lt;property name="brokerURL" value="tcp://192.168.25.168:61616" /&gt;
&lt;/bean&gt;
&lt;!-- Spring用於管理真正的ConnectionFactory的ConnectionFactory --&gt;
&lt;bean id="connectionFactory"
    class="org.springframework.jms.connection.SingleConnectionFactory"&gt;
    &lt;!-- 目標ConnectionFactory對應真實的可以產生JMS Connection的ConnectionFactory --&gt;
    &lt;property name="targetConnectionFactory" ref="targetConnectionFactory" /&gt;
&lt;/bean&gt;

</beans>
(3)配置生產者對象

使用jmsTemplate對象,發送消息

<!-- 配置生產者 -->
<!-- Spring提供的JMS工具類,它可以進行消息發送、接收等 -->
<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">
<!-- 這個connectionFactory對應的是我們定義的Spring提供的那個ConnectionFactory對象 -->
<property name="connectionFactory" ref="connectionFactory" />
</bean>
(4)在spring中配置Destination(有兩種方式:隊列 queue和主題 topic)

<!--這個是隊列目的地,點對點的 -->
<bean id="queueDestination" class="org.apache.activemq.command.ActiveMQQueue">
<constructor-arg>
<value>spring-queue</value>
</constructor-arg>
</bean>
<!--這個是主題目的地,一對多的 -->
<bean id="topicDestination" class="org.apache.activemq.command.ActiveMQTopic">
<constructor-arg value="topic" />
</bean>

(5)可以進行junit進行測試發送消息

@Test
public void testSpringActiveMq() throws Exception {
//初始化spring容器
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-activemq.xml");
//從spring容器中獲得JmsTemplate對象
JmsTemplate jmsTemplate = applicationContext.getBean(JmsTemplate.class);
//從spring容器中取Destination對象
Destination destination = (Destination) applicationContext.getBean("queueDestination");
//使用JmsTemplate對象發送消息。
jmsTemplate.send(destination, new MessageCreator() {

        @Override
        public Message createMessage(Session session) throws JMSException {
            //創建一個消息對象並返回
            TextMessage textMessage = session.createTextMessage("spring activemq queue message");
            return textMessage;
        }
    });
}

(6)接收消息

第一步:需要自定義messagerListener的實現類

public class MyMessageListener implements MessageListener {

@Override
public void onMessage(Message message) {

    try {
        TextMessage textMessage = (TextMessage) message;
        //取消息內容
        String text = textMessage.getText();
        System.out.println(text);
    } catch (JMSException e) {
        e.printStackTrace();
    }
}

}
第二步:在spring容器中配置自定義的消息監聽對象

&lt;!-- 接收消息 --&gt;
&lt;!-- 配置監聽器 --&gt;
&lt;bean id="myMessageListener" class="cn.e3mall.search.listener.MyMessageListener" /&gt;
&lt;!-- 消息監聽容器,屬性中引用的對象要和生產者的一致 --&gt;
&lt;bean class="org.springframework.jms.listener.DefaultMessageListenerContainer"&gt;
    &lt;property name="connectionFactory" ref="connectionFactory" /&gt;
    &lt;property name="destination" ref="queueDestination" /&gt;
    &lt;property name="messageListener" ref="myMessageListener" /&gt;
&lt;/bean&gt;

第三步:初始化一個spring容器,等待接收消息

@Test
public void testQueueConsumer() throws Exception {
//初始化spring容器
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-activemq.xml");
//等待
System.in.read();
}
至此,spring和activemq的整合過程完畢。需要注意的是activemq的新版本中核心jar包中集成了spring框架中的一些方法,但是不是太全,建議大家選擇版本的時候注意。
歡迎工作一到五年的Java工程師朋友們加入Java架構開發: 855835163
羣內提供免費的Java架構學習資料(裏面有高可用、高併發、高性能及分佈式、Jvm性能調優、Spring源碼,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個知識點的架構資料)合理利用自己每一分每一秒的時間來學習提升自己,不要再用"沒有時間“來掩飾自己思想上的懶惰!趁年輕,使勁拼,給未來的自己一個交代!

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