首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Spring侦听器接收导致CPU消耗的空消息

Spring侦听器接收导致CPU消耗的空消息
EN

Stack Overflow用户
提问于 2015-03-17 06:38:52
回答 1查看 886关注 0票数 0

我正在开发一个应用程序,它使用几个jms队列向外部系统发送/接收更新。为了测试我的应用程序,我使用了Mockrunner,特别是jms模块。我面临着一种奇怪的行为:当我启动我的应用程序时,我可以看到CPU以100%的速度飞速增长,通过分析线程转储,我可以看到主要原因是我拥有的jms侦听器看起来像是接收空消息--这导致消息如下:

代码语言:javascript
复制
Consumer ... did not receive a message

现在,我正试图了解这个问题是否与我的应用程序和mockrunner之间的糟糕交互有关,还是一个配置错误。

该组合的相关部分是:

代码语言:javascript
复制
<bean id="destinationManager" factory-bean="mockRunnerJMSObjectFactory" factory-method="getDestinationManager" />

<bean id="mockJmsConnectionFactory" factory-bean="mockRunnerJMSObjectFactory" factory-method="createMockConnectionFactory" lazy-init="true"/>

导致CPU无限期旋转的监听器是:

代码语言:javascript
复制
<jms:listener-container concurrency="5" connection-factory="mockJmsConnectionFactory" destination-type="queue" message-converter="myMessageConverter" acknowledge="transacted" >
    <jms:listener 
        id="myListener" 
        destination="myQueue" 
        ref="myConsumer" 
        method="consume"
    />
</jms:listener-container>

<bean id="myConsumer"... />

UPDATE I在Mockrunner项目上打开了一个问题,您可以看到它是这里

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-28 08:10:56

经过一些调查,我发现问题在于与SpringDefaultMessageListenerContainer的交互很差。该侦听器有一个基于轮询的实现,并且考虑到模拟的基础结构在响应请求时非常快,导致CPU过载。我通过在响应方法中添加一个丑陋的线程睡眠来修补模拟运行程序,也许这迟早会被修复。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29092788

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档