2

当向没有订阅者的 ActiveMQ 代理中的队列添加消息时,队列会填满,最终生产者线程挂起,无法发布更多消息。

为了解决这个问题,我设置了消息的过期时间,认为这会释放内存,但不幸的是这不起作用。有谁知道我该如何解决这个问题?

我的代理 ActiveMQ 版本是 5.7,代理定义是:

<bean id="mqBroker" class="org.apache.activemq.broker.BrokerService" init-method="start" destroy-method="stop">
    <property name="brokerName" value = "mainBroker"/>
    <property name="persistent" value="false"/>
    <property name="useJmx" value="false"/>
    <property name="transportConnectorURIs">
        <list>
            <value>tcp://localhost:7000</value>
        </list>
    </property>
</bean>

当 JConsole 无法向代理发布更多消息时查看 JConsole,内存使用情况看起来很好(使用率为 0%)并且过期计数 = 已发布计数。

我用来发布消息的代码与 spring 集成:

<jms:outbound-channel-adapter
    channel="jsonChannel"
    connection-factory="jmsConnectionFactory"
    pub-sub-domain="false"
    destination-name="MY_QUEUE"
    time-to-live="60000"
    wxplicit-qos-enabled="true" />
4

2 回答 2

3

Broker 会定期扫描队列以丢弃过期消息。问题是过期消息发生了什么。考虑到您的配置,它们可能最终会出现在 DLQ 中,因此您可能需要考虑配置丢弃策略以不将过期消息添加到 DLQ。请参阅有关该问题的 ActiveMQ文档

于 2013-10-02T18:01:41.863 回答
0

你是否

  • 用于message.setJMSExpiration(...);您的javax.jms.Message
  • 设置“生存时间”属性(专为主题发布而设计,但在特殊情况下也可用于队列)

?

于 2013-10-02T15:40:32.400 回答