我是靠谱客的博主 怕黑猫咪,最近开发中收集的这篇文章主要介绍activeMQ优点与和spring整合的xml配置,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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 -->

最后

以上就是怕黑猫咪为你收集整理的activeMQ优点与和spring整合的xml配置的全部内容,希望文章能够帮你解决activeMQ优点与和spring整合的xml配置所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(53)

评论列表共有 0 条评论

立即
投稿
返回
顶部