【发布时间】: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 个消费者最大值。不然我不知道
-
谢谢!这有帮助。请参阅下面的答案...