ActiveMQ(三)———spring消息持久化配置

一、Topic与Queue比较

1、Topic

  1. Publish Subscribe messaging 发布订阅消息。
  2. topic数据默认不落地,是无状态的。
  3. 并不保证publisher发布的每条数据,Subscriber都能接受到
  4. 一般来说publisher发布消息到某一个topic时,只有正在监听该topic地址的sub能够接收到消息;如果没有sub在监听,该topic就丢失了。
  5. 一对多的消息发布接收策略,监听同一个topic地址的多个sub都能收到publisher发送的消息。Sub接收完通知mq服务器。

2、Queue

  1. Point-to-Point 点对点。
  2. Queue数据默认会在mq服务器上以文件形式保存,比如Active MQ一般保存在$AMQ_HOMEdatakr-storedata下面。也可以配置成DB存储。
  3. Queue保证每条数据都能被receiver接收。
  4. Sender发送消息到目标Queue,receiver可以异步接收这个Queue上的消息。Queue上的消息如果暂时没有receiver来取,也不会丢失。
  5. 一对一的消息发布接收策略,一个sender发送的消息,只能有一个receiver接收。receiver接收完后,通知mq服务器已接收。

二、持久化监听Topic消息

在订阅发布模式的特点中,第4点默认情况下是只有正在监听的程序才能收到消息,那么如何让没有监听的程序启动开启监听之后也能收到消息呢?activeMQ也提供了相应的解决办法。下面结合spring来说明,其实很简单,只需要在生产者和消费者中添加相关配置即可。
在生产者相关配置,主要就是开启持久化以及声明是订阅发布模式:

<bean id="jmsTemplate" class="org.springframework.jms.core.JmsTemplate">  
    <!-- 进行持久化 -->
    <property name="deliveryMode" value="2" />
    <!--订阅 发布模式 -->
    <property name="pubSubDomain" value="true" />
    <property name="connectionFactory" ref="connectionFactory"/>  
</bean> 

消费者相关配置,主要的两点就是clientId和durableSubscriptionName。clientId是针对连接的,而durableSubscriptionName是针对消费者,因为一个连接可以有多个消费者,只有这两个属性才能让生产者记住是哪个连接上的哪个消费者,所以二者缺一不可,另外就是开启订阅持久化:

<bean id="connectionFactory" class="org.springframework.jms.connection.SingleConnectionFactory">  
    <!-- 标识连接者身份 -->
    <property name="clientId" value="client_001" />
    <property name="targetConnectionFactory" ref="targetConnectionFactory"/>  
</bean> 
<bean id="jmsContainer"  
        class="org.springframework.jms.listener.DefaultMessageListenerContainer">  
    <property name="connectionFactory" ref="connectionFactory" />  
    <property name="destination" ref="destination" />  
    <property name="messageListener" ref="consumerMessageListener" /> 
    <!-- 持久化消息 -->
    <property name="subscriptionDurable" value="true"/>  
    <property name="clientId" value="client_001" />  
    <property name="durableSubscriptionName" value="client_001"/>
    <bean id="jmsContainer2"  
        class="org.springframework.jms.listener.DefaultMessageListenerContainer">  
    <property name="connectionFactory" ref="connectionFactory" />  
    <property name="destination" ref="destination" />  
    <property name="messageListener" ref="consumerMessageListener" /> 
    <!-- 持久化消息 -->
    <property name="subscriptionDurable" value="true"/>  
    <property name="clientId" value="client_001" />  
    <property name="durableSubscriptionName" value="client_002"/>
</bean>

三、spring中的三种connectionFactory

  • SingleConnectionFactory:顾名思义只会创建一个共享的连接。
  • CachingConnectionFactory:继承了SingleConnectionFactory,所以它拥有SingleConnectionFactory的所有功能,同时它还新增了缓存功能,它可以缓存Session、MessageProducer和MessageConsumer。推荐使用,在并发量不是很高的情况下也是比较实用。
  • PooledConnectionFactory:只会缓存connection,session和productor,不会缓存consumer。并发量高的情况下比较实用。

相关内容推荐