`
baobeituping
  • 浏览: 1068723 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

ActiveMQ实战二

阅读更多

假设已经正确安装ActiveMQ5.0,同时及其IP地址为192.168.1.148,具体使用时可以改为自己的IP。下面讲解的配置实现的features如下:

  1. 客户端可以通过tcp://192.168.1.148连接ActiveMQ。
  2. 消息持久化保存,重启服务器不会丢失消息。
  3. 可以通过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/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd  
  •   http://activemq.org/config/1.0 http://activemq.apache.org/schema/activemq-core.xsd  
  •   http://activemq.apache.org/camel/schema/spring>  
  •    
  •   <!-- persistent="true"表示要持久化存储消息,和子元素persistenceAdapter结合使用 -->  
  •   <!-- dataDirectory默认的存储持久化数据的目录 -->  
  •   <!-- brokerName 设置broker的name,在注意在网络上必须是唯一的-->  
  •   <!-- 更多参考http://activemq.apache.org/xbean-xml-reference-50.html#XBeanXMLReference5.0-brokerelement -->  
  •   <broker xmlns="http://activemq.org/config/1.0" brokerName="192.168.1.148" persistent ="true" dataDirectory="${activemq.base}/data" useShutdownHook="false">  
  •    
  •     <!-- Destination specific policies using destination names or wildcards -->  
  •     <!-- wildcards意义见http://activemq.apache.org/wildcards.html -->  
  •     <destinationPolicy>  
  •       <policyMap>  
  •         <policyEntries>  
  •        <!-- 这里使用了wildcards,表示所有以EUCITA开头的topic -->  
  •           <policyEntry topic="EUCITA.>" producerFlowControl="false" memoryLimit="10mb">  
  •             <!-- 分发策略 -->  
  •         <dispatchPolicy>  
  •           <!-- 按顺序分发 -->  
  •               <strictOrderDispatchPolicy/>  
  •             </dispatchPolicy>  
  •         <!--  恢复策略-->  
  •             <subscriptionRecoveryPolicy>  
  •           <!-- 只恢复最后一个message -->  
  •               <lastImageSubscriptionRecoveryPolicy/>  
  •             </subscriptionRecoveryPolicy>  
  •           </policyEntry>  
  •         </policyEntries>  
  •       </policyMap>  
  •     </destinationPolicy>  
  •   
  •     <!-- The transport connectors ActiveMQ will listen to -->  
  •     <transportConnectors>  
  •        <transportConnector name="openwire" uri="tcp://192.168.1.148:61616" discoveryUri="multicast://default"/>  
  •        <transportConnector name="ssl"     uri="ssl://192.168.1.148:61617"/>  
  •        <transportConnector name="stomp"   uri="stomp://192.168.1.148:61613"/>  
  •        <transportConnector name="xmpp"    uri="xmpp://192.168.1.148:61222"/>  
  •     </transportConnectors>  
  •      
  •     <!-- 消息持久化方式 -->  
  •     <persistenceAdapter>  
  •       <amqPersistenceAdapter directory="${activemq.base}/data"/>  
  •     </persistenceAdapter>  
  • </broker>  
  •   
  •   <!-- lets create a command agent to respond to message based admin commands on the ActiveMQ.Agent topic -->  
  •     <commandAgent xmlns="http://activemq.org/config/1.0"/>  
  •     
  •   <!-- An embedded servlet engine for serving up the Admin console -->  
  •   <jetty xmlns="http://mortbay.com/schemas/jetty/1.0">  
  •     <connectors>  
  •       <nioConnector port="8161" />  
  •     </connectors>  
  •   
  •     <handlers>  
  •       <webAppContext contextPath="/admin" resourceBase="${activemq.base}/webapps/admin" logUrlOnStart="true" />       
  •       <webAppContext contextPath="/demo" resourceBase="${activemq.base}/webapps/demo" logUrlOnStart="true" />         
  •     </handlers>  
  •   </jetty>   
  • </beans> 
  • 注释

    关于XML配置中元素的具体信息可以参考http://activemq.apache.org/xbean-xml-reference-50.html 下面介绍本篇配置使用的一些重要元素。

    DispathPolicy

    ActiveMQ支持3中不同的分发策略(避免翻译了以后误解,这里用原文):

    1. <roundRobinDispatchPolicy>:Simple dispatch policy that sends a message to every subscription that matches the message.
    2. <simpleDispatchPolicy>:Simple dispatch policy that sends a message to every subscription that matches the message.
    3. <strictOrderDispatchPolicy>:Dispatch policy that causes every subscription to see messages in the same order.

    SubscriptionRecoveryPolicy

    ActiveMQ支持6种恢复策略,可以自行选择使用不同的策略

    1. <fixedCountSubscriptionRecoveryPolicy>: keep a fixed count of last messages.
    2. <fixedSizedSubscriptionRecoveryPolicy>: keep a fixed amount of memory available in RAM for message history which is evicted in time order.
    3. <lastImageSubscriptionRecoveryPolicy>:only keep the last message.
    4. <noSubscriptionRecoveryPolicy>:disable recovery of messages.
    5. <queryBasedSubscriptionRecoveryPolicy>:perform a user specific query mechanism to load any messages they may have missed.
    6. <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来存储,可以查找文档配置。 

    分享到:
    评论

    相关推荐

      activeMq 实战

      ### ActiveMQ 实战 #### JMS 基本构件概览 **ActiveMQ** 是一个高性能、功能丰富的开源消息中间件,它实现了 **Java Message Service (JMS)** 规范。JMS 规范定义了一组接口,这些接口提供了一个标准的方式来进行...

      ActiveMQ实战(英文版)

      **ActiveMQ实战(英文版)** ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它遵循Java消息服务(JMS)规范,支持多种协议,并且跨平台运行。这本书《ActiveMQ实战(英文版)》旨在深入探讨如何在实际环境中...

      ActiveMQ 实战

      ActiveMQ实战手册以介绍JMS和ActiveMQ的操作及配置为主,JMS(Java Message Service)是Java平台中对于面向消息中间件(MOM)的一种标准的API,用于在两个应用程序之间,或分布式系统中发送消息,进行异步通信。...

      activemq实战

      #### 三、ActiveMQ实战案例介绍 - **案例概述**:本书通过一系列实例来展示如何使用ActiveMQ构建各种应用场景下的消息传递系统。 - **目的**:通过实际案例帮助读者深入了解ActiveMQ的核心概念和技术细节,并学会...

      ActiveMQ集群实战视频教程

      ActiveMQ集群实战教程

      ActiveMQ实战资料

      **ActiveMQ实战资料详解** Apache ActiveMQ是Apache软件基金会开发的一款开源消息中间件,它是Java消息服务(Java Message Service,简称JMS)的一个实现。在分布式系统中,ActiveMQ扮演着至关重要的角色,它允许...

      ActiveMq实战性视频

      ActiveMq实战性视频

      activeMQ实战demo

      在这个“ActiveMQ实战demo”中,我们将深入探讨如何使用ActiveMQ进行消息发送和接收,并了解其工作原理。 首先,让我们了解一下JMS。JMS是Java平台上的一个标准接口,定义了生产、消费、管理和消息队列的标准API。...

      dubbo,zookeeper,activemq,redis,fastdfs实战操作文档

      ### Activemq实战操作 文档内容未提及ActiveMQ的具体操作,但通常ActiveMQ作为一个开源的消息中间件,在企业中用于实现异步消息传递和集成。 ### Redis实战操作 文档中没有明确提到Redis的使用,但作为高性能的...

      ACTIVEMQ实战 部分翻译(1——4.3)

      ActiveMQ是一种广泛使用的企业级消息中间件,它遵循JMS(Java Message Service)规范,为分布式系统中的不同应用提供可靠的消息传递服务。在本篇内容中,我们会深入探讨ActiveMQ的特性、安装与运行,以及它如何与...

      ActiveMQ实战——实现一个简易版的聊天室

      在本篇《ActiveMQ实战——实现一个简易版的聊天室》中,我们将深入探讨如何利用Apache ActiveMQ构建一个简单的在线聊天应用。ActiveMQ是Apache软件基金会的一个开源项目,它是一款功能强大的消息中间件,用于在...

      ActiveMq实战性视频-分布式

      从activemq入门到 实战-activemq集群与应用,分布式。货真价实

      ActiveMQDemo实战.pdf

      该文档《ActiveMQDemo实战.pdf》是一份详细的ActiveMQ项目实战教程,通过从项目搭建到使用的整个过程,向读者展示如何利用ActiveMQ进行消息队列应用的开发。 首先,文档中提到了项目结构,通常包含生产者(Producer...

      activemq实战项目,同ssh框架整合(生产者+消费者)

      通过这个实战项目,开发者可以深入理解如何在Java Web环境中使用ActiveMQ,以及如何解决在实际应用中可能出现的问题,如消息的可靠传输和幂等问题。同时,它也提供了一个良好的学习平台,帮助初学者掌握SSH与...

      spring boot ActiveMQ学习练习demo项目源码

      3. **Byte消息**:如果payload是二进制数据,如图像或音频文件,我们可以使用`BytesMessage`。它允许直接操作字节流,适用于任何类型的数据传输。 4. **Stream消息**:`StreamMessage`类似于Byte消息,但它允许连续...

      2019实战ActiveMQ集群与应用实战视频教程

      本视频教程通过实战的方式介绍了 ActiveMQ 的集群搭建与应用,涵盖了从基础概念到实际部署的全过程。通过学习这些知识点,不仅可以帮助开发者深入了解 ActiveMQ 的工作原理,还能够掌握如何在实际项目中有效地利用 ...

      使用ActiveMQ示例.pdf

      ActiveMQ 是 Apache 开源项目提供的一款高效、可靠的开源消息中间件,它实现了 Java 消息服务(Java Message Service,简称 JMS),为分布式系统中的应用提供了异步通信的能力。JMS 是一个工业标准,它定义了一组...

      自己实现的 ActiveMQ 多线程客户端 包含生产消息客户端和消费者消息客户端

      2. **多线程技术**: - **生产者多线程**:Amq_Producer_mt.cpp 文件可能包含了多个线程同时发送消息的实现,提高了消息发送的并发能力。 - **消费者线程**:Amq_Consumer.cpp 可能设计了一个线程来监听并处理来自...

    Global site tag (gtag.js) - Google Analytics