ActiveMq學習筆記(一)

本文爲自己學習使用的小記,僅供學習參考

前言:環境Mac os10.12.4 + idea 2017.1.2 + jdk1.8

ActiveMq整合spring 簡單實現

#進入mq的bin目錄,後臺啓動mq
cd /usr/local/apache-activemq-5.14.0/bin
nohup ./activemq start
#登陸後臺管理地址,用戶名:admin 密碼:admin
後臺管理地址 http://localhost:8161/

pom文件

	<!--版本控制-->
    <properties>
        <spring.version>4.3.8.RELEASE</spring.version>
        <activemq.version>5.14.5</activemq.version>
        <junit.version>4.12</junit.version>
    </properties>

    <dependencies>
        <!-- spring 框架 -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <!-- xbean-spring -->
        <dependency>
            <groupId>org.apache.xbean</groupId>
            <artifactId>xbean-spring</artifactId>
            <version>4.5</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jms</artifactId>
            <version>${spring.version}</version>
        </dependency>
        <!--spring 整合junit測試-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</artifactId>
            <version>${spring.version}</version>
        </dependency>

        <!-- 消息隊列 MQ -->
        <dependency>
            <groupId>org.apache.activemq</groupId>
            <artifactId>activemq-all</artifactId>
            <version>${activemq.version}</version>
        </dependency>

        <!--測試-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
    </dependencies>

生產者spring相關配置

<!-- ActiveMQ 連接工廠 -->
    <!-- 真正可以產生Connection的ConnectionFactory,由對應的 JMS服務廠商提供-->
    <!-- 如果連接網絡:tcp://ip:61616;未連接網絡:tcp://localhost:61616 以及用戶名,密碼-->
    <amq:connectionFactory id="amqConnectionFactory"
        brokerURL="tcp://localhost:61616" userName="admin" password="admin" /> 
 
    <!-- Spring Caching連接工廠 -->
    <!-- Spring用於管理真正的ConnectionFactory的ConnectionFactory -->  
    <bean id="mqConnectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">
        <!-- 目標ConnectionFactory對應真實的可以產生JMS Connection的ConnectionFactory -->  
        <property name="targetConnectionFactory" ref="amqConnectionFactory"></property>
        <!-- 同上,同理 -->
        <!-- <constructor-arg ref="amqConnectionFactory" /> -->
        <!-- Session緩存數量 -->
        <property name="sessionCacheSize" value="100" />
    </bean>
    
     <!-- Spring JmsTemplate 的消息生產者 start-->

    <!-- 定義JmsTemplate的Queue類型 -->
    <bean id="jmsQueueTemplate" class="org.springframework.jms.core.JmsTemplate">
        <!-- 這個connectionFactory對應的是我們定義的Spring提供的那個ConnectionFactory對象 -->  
        <constructor-arg ref="mqConnectionFactory" />
        <!-- 非pub/sub模型(發佈/訂閱),即隊列模式 -->
        <property name="pubSubDomain" value="false" />
    </bean>

    <!-- 定義JmsTemplate的Topic類型 -->
    <bean id="jmsTopicTemplate" class="org.springframework.jms.core.JmsTemplate">
         <!-- 這個connectionFactory對應的是我們定義的Spring提供的那個ConnectionFactory對象 -->  
        <constructor-arg ref="mqConnectionFactory" />
        <!-- pub/sub模型(發佈/訂閱) -->
        <property name="pubSubDomain" value="true" />
    </bean>

    <!--Spring JmsTemplate 的消息生產者 end-->

測試類

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:applicationContext.xml")
public class TestMq {
    @Autowired
    private JmsTemplate jmsTemplate;

    @Test
    public void testMqQueues() {
        jmsTemplate.send("testMqQueues", new MessageCreator() {
            public Message createMessage(Session session) throws JMSException {

                MapMessage mapMessage = session.createMapMessage();

                mapMessage.setString("testMqQueues", "testMqQueues");

                return mapMessage;
            }
        });
    }
}

mq消息隊列

這裏寫圖片描述

消費端spring配置

<!--掃描到spring註解的bean-->
<context:component-scan base-package="com.hyj.mq"/>
<!-- ActiveMQ 連接工廠 -->
    <!-- 真正可以產生Connection的ConnectionFactory,由對應的 JMS服務廠商提供-->
    <!-- 如果連接網絡:tcp://ip:61616;未連接網絡:tcp://localhost:61616 以及用戶名,密碼-->
    <amq:connectionFactory id="amqConnectionFactory" 
        brokerURL="tcp://localhost:61616" userName="admin" password="admin"  />
 
    <!-- Spring Caching連接工廠 -->
    <!-- Spring用於管理真正的ConnectionFactory的ConnectionFactory -->  
    <bean id="connectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">
        <!-- 目標ConnectionFactory對應真實的可以產生JMS Connection的ConnectionFactory -->  
        <property name="targetConnectionFactory" ref="amqConnectionFactory"></property>
        <!-- 同上,同理 -->
        <!-- <constructor-arg ref="amqConnectionFactory" /> -->
        <!-- Session緩存數量 -->
        <property name="sessionCacheSize" value="100" />
    </bean>
    
     <!-- 消息消費者 start-->

    <!-- 定義Queue監聽器 -->
    <jms:listener-container destination-type="queue" container-type="default" 
    	connection-factory="connectionFactory" acknowledge="auto">
        <!-- 默認註冊bean名稱,應該是類名首字母小寫  -->
        <jms:listener destination="testMqQueues" ref="queueService"/>
    </jms:listener-container>
    
    <!-- 定義Topic監聽器 -->
<!--     <jms:listener-container destination-type="topic" container-type="default"  -->
<!--     	connection-factory="connectionFactory" acknowledge="auto"> -->
<!--         <jms:listener destination="spring_topic" ref="topicConsumer1"/> -->
<!--         <jms:listener destination="spring_topic" ref="topicConsumer2"/> -->
<!--     </jms:listener-container> -->

    <!-- 消息消費者 end -->

消費端service

@Service
public class QueueService implements MessageListener {

    public void onMessage(Message message) {

        MapMessage mapMessage = (MapMessage) message;
        try {
            System.out.println("消費者QueueService獲取消息:" + mapMessage.getString("testMqQueues"));
        } catch (JMSException e) {
            e.printStackTrace();
        }
    }
}

消費端test

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:applicationContext.xml")
public class TestMq1 {
    @Autowired
    private JmsTemplate jmsTemplate;

    @Test
    public void testMqQueues() {
        while (true){
            //保證線程不關閉,一直監聽消息隊列
        }
    }
}

mq消息隊列

這裏寫圖片描述

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