【问题标题】:concurrentConsumers for an ActiveMQ queueActiveMQ 队列的并发消费者
【发布时间】:2012-08-11 00:13:01
【问题描述】:

我尝试使用 grails 中 ActiveMQ 队列中的消息。我已经为连接配置了一些 spring bean,到目前为止一切正常。

当我尝试将concurrentConsumers 设置为高于 8 时,问题就开始了。似乎将 8 设置为一个客户端的最大值 - 如果我配置超过 8 个,ActiveMQ 资源管理器仍然显示队列的 8 个使用者。如果我为超过 8 个concurrentConsumers 的不同队列配置两个侦听器,ActiveMQ oszillate 显示的消费者数量,但总和始终为 8。

我做错了什么?配置示例显示 concurrentConsumers 最多为 50...

这是我的配置,写成groovy DSL,我想看下去应该没问题...

jmsFactory(org.apache.activemq.pool.PooledConnectionFactory) { bean ->
    bean.destroyMethod = "stop"
    connectionFactory = { org.apache.activemq.ActiveMQConnectionFactory cf ->
        brokerURL = "tcp://localhost:61616"
    }
}
jmsTemplate(org.springframework.jms.core.JmsTemplate) {
    connectionFactory = jmsFactory
}
jmsMessageListener(org.springframework.jms.listener.adapter.MessageListenerAdapter, ref("messageService")) {
    defaultListenerMethod = "onMessage"
}
jmsContainer(org.springframework.jms.listener.DefaultMessageListenerContainer) {
    connectionFactory = jmsFactory
    concurrency="10"
    concurrentConsumers="15"
    destinationName = "demoQueue"
    messageListener = jmsMessageListener
    transactionManager = ref("transactionManager")
    autoStartup = false
}    
jmsMessageListener2(org.springframework.jms.listener.adapter.MessageListenerAdapter, ref("messageService")) {
    defaultListenerMethod = "onMessage2"
}
jmsContainer2(org.springframework.jms.listener.DefaultMessageListenerContainer) {
    connectionFactory = jmsFactory
    destinationName = "demoQueue2"
    messageListener = jmsMessageListener2
    transactionManager = ref("transactionManager")
    autoStartup = false
}    

【问题讨论】:

  • 不确定是否有帮助,但您应该设置“并发”或“concurrentConsumers/maxConcurrentConsumers”,因为它们重叠。 concurrency="10-15" 将设置 concurrentConsumers=10、maxConcurrentConsumers=15 等。
  • 谢谢。试一试 - 没有任何变化...... :-(
  • 用 jconsole 连接到 activemq,看看这是否与 activemq 的 web 控制台中的消费者数量不匹配。据我所知,在活动 mq 或 spring 中没有定义 8 个消费者最大值。不然我不知道
  • 谢谢!这有帮助。请参阅下面的答案...

标签: spring activemq


【解决方案1】:

由于 Petter 指出 ActiveMQ 或 Spring 配置不会有问题,所以我在 java 中创建了一个 spring 消费者,并试图找到与我的 grails 消费者不同的地方。

java 消费者按预期工作,但不使用事务管理器。所以我从我的 grails confid 中删除了事务管理器,它可以工作了!

然后我google了一下,发现了cacheLevel设置的提示:http://static.springsource.org/spring/docs/2.0.8/api/org/springframework/jms/listener/DefaultMessageListenerContainer.html#setCacheLevel%28int%29

使用事务管理器时,cacheLevel 设置为 none - 宾果游戏!如果我现在将 cacheLevel 设置为 CACHE_CONSUMER,一切都会按预期工作......

【讨论】:

  • 很好的调查。事务经理有一个讨厌的习惯,就是想以自己的方式做事。
猜你喜欢
  • 2014-06-27
  • 2021-11-25
  • 2015-02-02
  • 2015-06-25
  • 2019-03-21
  • 2019-02-26
  • 1970-01-01
  • 2016-05-16
  • 1970-01-01
相关资源
最近更新 更多