Activemq嵌入式代理和故障转移消费者群集

时间:2012-01-19 08:25:52

标签: spring activemq cluster-computing

环境

  • 现有的软件采用专有的聚类方式,应该转移到使用JMS
  • 客户不想支付设置和维护费用 消息传递系统,所以只有我可以嵌入整个系统才能使用它 消息传递到现有虚拟机
  • 代理实例和使用者应该在同一个JVM中。消费者 应该能够在故障转移情况下连接到远程代理,因为无论运行哪个JVM,所有消费者都应该有一个输入队列。
  • 如果消费者使用直接方法调用会很好 与当地经纪人沟通

演示项目

我用ActiveMQ + Maven + Spring创建了一个非常简单的demo(eclipse)项目(整个项目位于http://www.woofiles.com/dl-279452-fOcsWkcm-activemq.zip)。如果您尝试它,请更改activemq的dataDirectory,因为它是有线绝对路径,直到现在。

我尝试从春天开始经纪人,还有一群消费者。请参阅下面的Spring配置:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:amq="http://activemq.apache.org/schema/core" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p" xmlns:task="http://www.springframework.org/schema/task"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://activemq.apache.org/schema/core
http://activemq.apache.org/schema/core/activemq-core.xsd
http://www.springframework.org/schema/task
http://www.springframework.org/schema/task/spring-task-3.0.xsd">

    <bean id="propertyConfigurer"
        class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="systemPropertiesModeName" value="SYSTEM_PROPERTIES_MODE_FALLBACK" />
    </bean>
        <bean id="embeddedBroker" class="org.apache.activemq.broker.BrokerService"
            destroy-method="stop" init-method="start" >
            <property name="brokerName" value="conversion" />
            <property name="dataDirectory"
                value="c:\eclipseWithMaven\activemq\working\conversion" />
            <property name="schedulerSupport" value="false" />
            <property name="transportConnectorURIs">
                <list>
                    <value>tcp://127.0.0.1:600${idOfClusterNode}</value>
                </list>
            </property>
            <property name="managementContext">
                <bean class="org.apache.activemq.broker.jmx.ManagementContext">
                    <property name="connectorPort" value="201${idOfClusterNode}" />
                </bean>
            </property>
        </bean>

    <!-- depends-on see why at http://activemq.apache.org/vm-transport-reference.html -->
    <!--depends-on="embeddedBroker" -->
    <bean id="jmsFactory" class="org.apache.activemq.ActiveMQConnectionFactory" depends-on="embeddedBroker">
        <property name="brokerURL">
            <value>failover:(vm:/conversion,tcp://127.0.0.1:6001,tcp://127.0.0.1:6002)</value>
        </property>
    </bean>
    <bean id="cachedConnectionFactory"
        class="org.springframework.jms.connection.CachingConnectionFactory"
        p:targetConnectionFactory-ref="jmsFactory" p:sessionCacheSize="10" />
    <bean id="container"
        class="org.springframework.jms.listener.SimpleMessageListenerContainer">
        <property name="concurrentConsumers" value="10" />
        <property name="connectionFactory" ref="cachedConnectionFactory" />
        <property name="messageListener" ref="conversion" />
        <property name="destination" ref="conversionInputQueue" />
    </bean>
    <bean id="conversionInputQueue" class="org.apache.activemq.command.ActiveMQQueue">
        <constructor-arg value="conversionInputQueue" />
    </bean>
    <bean id="conversion" class="activemq.Conversion"
        p:clusterId="${idOfClusterNode}" />
</beans>

我只是尝试启动一个或两个activemq.ConversionDemo类的实例,其中包含spring&amp; amp; log4j配置。运行配置的环境条目如下所示:

  • 实例1:-DidOfClusterNode = 1 -DidOfOtherClusterNode = 2 -DlogFile = conversion1.log
  • 实例2:-DidOfClusterNode = 2 -DidOfOtherClusterNode = 1 -DlogFile = conversion2.log

如果我启动一个实例,那很好。如果两个正在运行,则会出现以下问题:

  • 第二个经纪人根本不会启动。它说它没有锁。它很好,但我认为,它只是异步启动一个线程,并将控制权交还给spring。但似乎它不会让春天继续下去。
  • SimpleMessageListenerContainer似乎也拿着控件 过了春天,直到所有消费者都开始了。

我想要什么

  • 我想满足上述要求
  • 我想我必须异步启动经纪人和消费者, 这个配置
  • 在春天我真的无法做到
  • 在经纪人之间实现真正的负载平衡会很不错。似乎ActiveMQ仅为故障转移做好准备。
  • 如果ActiveMQ无法满足我的需求,请推荐 其他免费解决方案。

如果您需要进一步的信息,请告诉我。

修改

我认为ActiveMQ支持我的需求,我只需要理解&#34;经纪人网络&#34;。所以我想我必须拥有两个文件存储,以及来自我的两个经纪人的网络。

1 个答案:

答案 0 :(得分:3)

如果您指向同一个文件存储中的2个代理,那么第一个将获得锁定,第二个将阻塞,直到锁定被释放...这是shared file system master/slave设置

如果您想要主动/主动设置,那么您需要使用单独的文件存储并将它们连接在一起network of brokers