/**
*作者:andyao,email:andyaoy@gmail.com
*http://andyao.iteye.com/blog/154092
*/
ActiveMQ5.0实战一: 安装配置ActiveMQ5.0
ActiveMQ5.0实战三:使用Spring发送,消费topic和queue消息
简介
上一篇http://www.iteye.com/topic/15317介绍了ActiveMQ5.0的安装,这一篇将介绍的配置。ActiveMQ包含了很多features(详见http://activemq.apache.org/features.html),
不同的需求,不同的环境,需要不同的features,当然需要不同的配置。在这里我只写了最基本的配置,算是抛砖了,希望引出更多关于ActiveMQ的高级配置。
假设已经正确安装ActiveMQ5.0,同时及其IP地址为192.168.1.148,具体使用时可以改为自己的IP。下面讲解的配置实现的features如下:
-
客户端可以通过tcp://192.168.1.148连接ActiveMQ。
-
消息持久化保存,重启服务器不会丢失消息。
-
可以通过http://192.168.1.148:8161/admin监控ActiveMQ服务器
配置
ActiveMQ默认使用的是XML格式配置,从4.0版本开始用MBean的方式实现XML配置,配置文件在${activemq.home}/conf目录下,文件名为activemq.xml。最新的默认配置见
http://svn.apache.org/repos/asf/activemq/trunk/assembly/src/release/conf/activemq.xml。下面为本篇文章使用的配置,及重要部分的解释。
-
<beans
-
xmlns="http://www.springframework.org/schema/beans"
-
xmlns:amq="http://activemq.org/config/1.0"
-
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-2.0.xsd
-
http://activemq.org/config/1.0http://activemq.apache.org/schema/activemq-core.xsd
-
http://activemq.apache.org/camel/schema/spring>
-
-
-
-
-
-
<brokerxmlns="http://activemq.org/config/1.0"brokerName="192.168.1.148"persistent="true"dataDirectory="${activemq.base}/data"useShutdownHook="false">
-
-
-
-
<destinationPolicy>
-
<policyMap>
-
<policyEntries>
-
-
<policyEntrytopic="EUCITA.>"producerFlowControl="false"memoryLimit="10mb">
-
-
<dispatchPolicy>
-
-
<strictOrderDispatchPolicy/>
-
</dispatchPolicy>
-
-
<subscriptionRecoveryPolicy>
-
-
<lastImageSubscriptionRecoveryPolicy/>
-
</subscriptionRecoveryPolicy>
-
</policyEntry>
-
</policyEntries>
-
</policyMap>
-
</destinationPolicy>
-
-
-
<transportConnectors>
-
<transportConnectorname="openwire"uri="tcp://192.168.1.148:61616"discoveryUri="multicast://default"/>
-
<transportConnectorname="ssl"uri="ssl://192.168.1.148:61617"/>
-
<transportConnectorname="stomp"uri="stomp://192.168.1.148:61613"/>
-
<transportConnectorname="xmpp"uri="xmpp://192.168.1.148:61222"/>
-
</transportConnectors>
-
-
-
<persistenceAdapter>
-
<amqPersistenceAdapterdirectory="${activemq.base}/data"/>
-
</persistenceAdapter>
-
</broker>
-
-
-
<commandAgentxmlns="http://activemq.org/config/1.0"/>
-
-
-
<jettyxmlns="http://mortbay.com/schemas/jetty/1.0">
-
<connectors>
-
<nioConnectorport="8161"/>
-
</connectors>
-
-
<handlers>
-
<webAppContextcontextPath="/admin"resourceBase="${activemq.base}/webapps/admin"logUrlOnStart="true"/>
-
<webAppContextcontextPath="/demo"resourceBase="${activemq.base}/webapps/demo"logUrlOnStart="true"/>
-
</handlers>
-
</jetty>
-
</beans>
注释
关于XML配置中元素的具体信息可以参考http://activemq.apache.org/xbean-xml-reference-50.html下面介绍本篇配置使用的一些重要元素。
DispathPolicy
ActiveMQ支持3中不同的分发策略(避免翻译了以后误解,这里用原文):
-
<roundRobinDispatchPolicy>:Simple dispatch policy that sends a message to every subscription that matches the message.
-
<simpleDispatchPolicy>:Simple dispatch policy that sends a message to every subscription that matches the message.
-
<strictOrderDispatchPolicy>:Dispatch policy that causes every subscription to see messages in the same order.
SubscriptionRecoveryPolicy
ActiveMQ支持6种恢复策略,可以自行选择使用不同的策略
-
<fixedCountSubscriptionRecoveryPolicy>: keep a fixed count of last messages.
-
<fixedSizedSubscriptionRecoveryPolicy>: keep a fixed amount of memory available in RAM for message history which is evicted in time order.
-
<lastImageSubscriptionRecoveryPolicy>:only keep the last message.
-
<noSubscriptionRecoveryPolicy>:disable recovery of messages.
-
<queryBasedSubscriptionRecoveryPolicy>:perform a user specific query mechanism to load any messages they may have missed.
-
<timedSubscriptionRecoveryPolicy>:keep a timed buffer of messages around in memory and use that to recover new subscriptions.
PersistenceAdapter
http://activemq.apache.org/persistence讲解了关于persistence的信息。ActiveMQ5.0使用AMQ
Message Store持久化消息,这种方式提供了很好的性能(The AMQ Message Store is an embeddable transactional message storage solution that is extremely fast and reliable.) 默认使用该存储方式即可,如果想使用JDBC来存储,可以查找文档配置。
Summary
本篇文章只提供了基本配置信息。如果需要更多的文章,可以查看ActiveMQ的文档。
讲了安装和简单的配置,下一篇将介绍和Sping的整合,以及多个queue,多个topic,多个producer,多个consumer的配置,使用。
分享到:
相关推荐
activemq实战
最新的activemq版本,刚开始写jms,希望大家都能用到
博文链接:https://cddcdd.iteye.com/blog/170685
ActiveMQ集群实战教程
n 二: ActiveMQ安装和基本使用 包括:通过源码安装、基本的配置示例、启动、测试运行、关闭等 n 三:理解和掌握JMS 包括:基本概念、消息结构、可靠性机制、PTP、Pub/Sub、API结构、JMS应用开 发的基本步骤、持久和...
springboot+activemq, 用代码讲解了activemq的2中处理模式:PTP与PUB/SUB, 具体讲解已经在文章中介绍过了
ActiveMQ 实战。本手册介绍了JMS以及ActiveMQ的常用操作以及配置。可以作为ActiveMQ应用开发人员的参考手册。
activemq实战
ActiveMQ实战(英文版) ActiveMQ实战(英文版) ActiveMQ实战(英文版)
该资源是spring与activemq的基础整合,适合消息中间件的初学者
"ActiveMQ5.13 安装与配置" ActiveMQ 是 Apache 软件基金会提供的一个开源message broker,能够实现点对点(Point-to-Point)和发布/订阅(Publish/Subscribe)模式的消息传递。ActiveMQ 5.13 是 ActiveMQ 的一个...
含如下内容:JMS API;Apache-activeMQ;ActiveMQ实战pdf
ActiveMQ 入门实战(3)--SpringBoot 整合 ActiveMQ(csdn)————程序
activeMQ-5.15版本,里面更改了activeMQ配置,新增了mysql的连接内容。lib里添加了durid和mysql连接的jar文件
ActiveMQ5.0 的二进制发布包中bin目录中包含一个名为activemq的脚本,直接运行这个脚本就可以启动一个broker。
ActiveMQ_使用failover模式进行连接切换时,线程断开 ,ActiveMQ_使用failover模式进行连接切换时,线程断开
activemq-all-5.8.0.jar 下载 activemq-all-5.8.0.jar 下载 activemq-all-5.8.0.jar 下载 activemq-all-5.8.0.jar 下载 activemq-all-5.8.0.jar 下载
linux下activemq安装包和配置文档