[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]Spring+JMS+Http请求导致的线程挂起。

上一篇:[备忘]SimpleDateFormat解析错误日期,不报错的问题
下一篇:[备忘]spring+activeMq,配置消费者的个数

添加日期:2016/6/18 23:21:12 快速返回   返回列表 阅读1863次
一个数据同步工程,
(1)检索数据,写入文件,发送activeMq消息
(2)消费者获取消息,处理数据,中途会有http请求其他url
现象:某天凌晨3点,消费者请求url后,无响应,消费者线程挂起,再也不执行了……

Spring里JMS设置,也就是指定listener是哪个bean,消息来了执行哪个方法。


 <bean id="dataImportMQListenerContainer" class="org.springframework.jms.listener.DefaultMessageListenerContainer">
        <property name="connectionFactory" ref="connectionFactory" />
        <property name="destination" ref="dataImportMQ" />
        <property name="messageListener" ref="dataImportMQListener" />
    </bean>



搜索后,发现少写一个参数:
<property name="concurrentConsumers" value="6"/>
即消费者个数,该值默认是1.
即只有一个消费者处理消息,处理完一个,才能处理下一个。

查看消费者调用url的代码,发现http请求没有设置connectionTimeout和socketTimeout.
查看日志,请求时,连接已经建立,
那么应该是连接建立后,远程服务器碰巧重启等原因,导致无响应,
而此处还傻乎乎的等待,由于无socketTimeout超时设置,导致无限等待。

而碰巧消费者只有一个,导致无法处理消息,现象就是数据未同步。

解决方法:
(1)修改http请求代码,设置超时。改成异步处理是最好了。
(2)配置JMS消费者,设置为多个。
(3)能否监控消费者状态?
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved