activeMQ优点与和spring整合的xml配置

来源:互联网 发布:淘宝网自助开通在哪里 编辑:程序博客网 时间:2024/05/29 08:22

activeMQ属于消息队列的一种,消息队列有的优点它都有。
主要有三点优点:
1.解决了访问应用同步处理时需要等待的问题。
消息队列就像一个中介,你可以把一堆需要事件响应的任务交给消息队列处理,这样你程序就可以不必等待,可以继续往下执行。而消息队列会完成你生产出的任务,而且原先写在代码中的两个流程本来需要顺序执行,交给消息队列后,消息队列可以在同一时间分别执行两个流程。把同步变成了异步处理。
2.应用解耦
把要和数据库交互的操作交给消息队列处理,这样就算数据库暂时不能保存数据也不影响前面代码的执行,交由消息队列在能存数据的时候存数据。达到解耦合的目的。
3.流量削峰
在商城的秒杀活动时,高访问量对于服务器的负担很大,如果实时的向数据库中存储数据时数据库很容易挂掉,在这时把存储操作都交给消息队列,由消息队列在服务器空闲时做存储操作。这样前台的数据也不会丢失,同时也解决了数据库的高并发访问问题。

activeMQ的与spring整合xml配置

<!-- ActiveMQ 连接工厂 -->    <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供-->    <!-- 如果连接网络:tcp://ip:61616;未连接网络:tcp://localhost:61616 以及用户名,密码-->    <bean id="amqConnectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">        <constructor-arg index="0" value="admin"></constructor-arg>        <constructor-arg index="1" value="admin"></constructor-arg>        <constructor-arg index="2" value="tcp://localhost:61616"></constructor-arg>    </bean>    <!-- 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>     <!-- Spring JmsTemplate 的消息生产者 start-->    <!-- 定义JmsTemplate的Queue类型 -->    <bean id="jmsQueueTemplate" class="org.springframework.jms.core.JmsTemplate">        <!-- 这个connectionFactory对应的是我们定义的Spring提供的那个ConnectionFactory对象 -->          <constructor-arg ref="connectionFactory" />        <!-- 非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="connectionFactory" />        <!-- pub/sub模型(发布/订阅) -->        <property name="pubSubDomain" value="true" />    </bean>    <!--Spring JmsTemplate 的消息生产者 end-->    <!-- 消息消费者 start-->    <!-- 定义Queue监听器 -->    <jms:listener-container destination-type="queue" container-type="default" connection-factory="connectionFactory" acknowledge="auto">        <jms:listener destination="test.queue" ref="queueReceiver1"/>        <jms:listener destination="test.queue" ref="queueReceiver2"/>    </jms:listener-container>    <jms:listener-container destination-type="queue" container-type="default" connection-factory="connectionFactory" acknowledge="auto">        <jms:listener destination="test.map" ref="queueReceiver3"/>    </jms:listener-container>    <!-- 定义Topic监听器 -->    <jms:listener-container destination-type="topic" container-type="default" connection-factory="connectionFactory" acknowledge="auto">        <jms:listener destination="test.topic" ref="topicReceiver1"/>        <jms:listener destination="test.topic" ref="topicReceiver2"/>    </jms:listener-container>    <!-- 消息消费者 end -->
原创粉丝点击