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 -->
阅读全文
0 0
- activeMQ优点与和spring整合的xml配置
- Spring与ActiveMQ的整合
- Spring与ActiveMQ的整合
- activemq与spring的整合
- activeMQ和spring的整合
- Spring与ActiveMQ整合
- Spring与ActiveMQ整合
- ActiveMQ 与spring整合
- Spring与ActiveMQ整合
- activemq与spring整合
- ActiveMQ与Spring整合
- ActiveMQ和spring整合
- ActiveMQ和spring整合
- Spring和ActiveMQ整合
- Spring整合ActiveMQ与Quartz的实例
- Spring与ActiveMQ(JMS)的整合说明
- ActiveMQ与Spring的整合使用
- Spring和ActiveMQ整合的完整例子
- 五、集合
- 51入门基础知识储备---ROM与RAM:计算机中的2种存储器
- C++11多线程互斥锁的使用
- python高效编程技巧6(如何实现用户的历史记录功能)
- 【BZOJ】1087 [SCOI2005]互不侵犯King 状压DP
- activeMQ优点与和spring整合的xml配置
- Java clone
- 写函数去除字符串中包含的非字母字符(不包括空格),将小写字母转换成大写字母
- SpringBoot JPA 条件分页
- python高效编程技巧7(pickle的使用:可以将一个对象存储在一个文件中,或者load进来)
- SD卡规范解读
- Gym 101246.G
- ACM刷题狗的心路历程1
- 周志华机器学习第二章习题