转载请注明出处:http://blog.csdn.net/l1028386804/article/details/69046395

解决使用activemq时抛出的异常:javax.j ms.JMSException: Could not connect to broker URL

我使用的是spring jms和activemq结合,在配置文件中定义了普通的connectionFactory的bean,如下所示:


  1. <bean id="connectionFactory" class="org.apache.activemq.ActiveMQConnectionFactory">
  2. <description>JMS连接工厂</description>
  3. <property name="brokerURL" value="tcp://192.168.50.131:61616" />
  4. </bean>

定义了上面的文件之后,在使用spring jms的JmsTemplate发送jms消息时,如果发送大量消息的话,有时候会抛出如下异常:

org.springframework.jms.UncategorizedJmsException: Uncategorized exception occured during JMS
processing; nested exception is javax.jms.JMSException: Could not connect to broker
URL: tcp://192.168.50.131:61616. Reason: java.net.BindException: Address already in use: connect
at org.springframework.jms.support.JmsUtils.convertJmsAccessException(JmsUtils.java:316)
at org.springframework.jms.support.JmsAccessor.convertJmsAccessException(JmsAccessor.java:168)
at org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:469)
at org.springframework.jms.core.JmsTemplate.send(JmsTemplate.java:534)
at net.kentop.astoam.device.MG800DeviceService.excute(MG800DeviceService.java:423)
at net.kentop.astoam.device.MG800DeviceService$HandlerReceiveMessage.
handlerUdpData(MG800DeviceService.java:936)
at net.kentop.mon4mg.monitor.UDPReceiverThread.run(UDPReceiverThread.java:51)
Caused by: javax.jms.JMSException: Could not connect to broker URL: tcp://192.168.20.23:61616.
Reason: java.net.BindException: Address already in use: connect
at org.apache.activemq.util.JMSExceptionSupport.create(JMSExceptionSupport.java:35)
at org.apache.activemq.ActiveMQConnectionFactory.
createActiveMQConnection(ActiveMQConnectionFactory.java:286)
at org.apache.activemq.ActiveMQConnectionFactory.
createActiveMQConnection(ActiveMQConnectionFactory.java:230)
at org.apache.activemq.ActiveMQConnectionFactory.
createConnection(ActiveMQConnectionFactory.java:178)
at org.springframework.jms.support.JmsAccessor.createConnection(JmsAccessor.java:184)
at org.springframework.jms.core.JmsTemplate.execute(JmsTemplate.java:456)
... 4 more

而且在运行的时候会增加很多activemq的线程,使得整个程序运行起来比较慢。通过观察,猜测主要原因是连接activemq时,没有使用池连接,导致每次发送jms消息时,用的不是同一个连接,而是创建一个新的连接,所以耗费很多系统资源,并且因为整个项目是多线程的,所以就会抛出如上面的异常。解决方法是将activemq的连接的bean定义为activemq的池连接定义,将配置文件中的connectionFactory的bean定义改为如下内容:


  1. <bean id="connectionFactory" class="org.apache.activemq.pool.PooledConnectionFactory">
  2. <property name="connectionFactory">
  3. <bean class="org.apache.activemq.ActiveMQConnectionFactory">
  4. <property name="brokerURL" value="tcp://192.168.50.131:61616" />
  5. </bean>
  6. </property>
  7. </bean>

修改之后重新运行程序,再测试。果然没有占用那么多资源,而且也不会抛出上面的异常了。

注意:要使用activemq的池连接,必须在classpath中包含有activemq-pool.jar

最新文章

  1. android——自定义listView
  2. 【写给大家看的CSS】定位元素:使用position/display布局
  3. oracle xmltype导入并解析Excel数据--前言
  4. Ubuntu 下配置Ganglia监控
  5. 【131202】SQL
  6. jsTree 的简单用法--异步加载和刷新数据
  7. 获取表单选中的值(利用php和js两种方式)
  8. SQL事务的使用
  9. 最近adt升级引起的问题
  10. CCF2014093字符串匹配(C语言版)
  11. Android学习笔记-ScrollView(滚动条)
  12. gitlab搭建和使用
  13. final,static,abstract
  14. CodeForces 550E Brackets in Implications 推理
  15. opencv知识积累
  16. @WebService @WebMethod 详解
  17. mongodb int型id 自增
  18. html学习第一讲(内容html常规控件的的使用)
  19. 检查office2016激活时间
  20. matplotlib之极坐标系的极角网格线(thetagrids)的显示刻度

热门文章

  1. Webpack学习-Webpack初识
  2. CSS快速入门-属性和伪类
  3. 基于.NET的3D开发框架/工具比较
  4. ESLint 规则详解(二)
  5. A1043 Is It a Binary Search Tree (25 分)
  6. Linux内核分析— —计算机是如何工作的(20135213林涵锦)
  7. 小学四则运算APP 第一个冲刺阶段 第四天
  8. 3D开机动画
  9. [转帖]第二个显示屏上禁用Windows任务栏
  10. download &amp; excel &amp; blob