一个数据同步工程, (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)能否监控消费者状态?
|