springboot之ActiveMQ连接池【踩坑】

踩过了才知道有坑,很久之前开发了一个程序,跑了快半年了,往ActiveMQ送数据。

最近发现,把MQ给连死了,每分钟五千条数据,造了五千个连接(TIME_WAIT)。

之前开发没有深究,随便百度了一下,网上基本都是这样的套路。spring.activemq.pool.enabled=false时,每发送一条数据创建一个连接。。。。。

spring.activemq.broker-url=tcp://127.0.0.1:61616
spring.activemq.in-memory=false
spring.activemq.pool.enabled=false

从坑里爬起来,必须搞连接池。

spring.activemq.broker-url=tcp://127.0.0.1:61616
spring.activemq.in-memory=false
#true表示使用连接池
spring.activemq.pool.enabled=true
#连接池最大连接数
spring.activemq.pool.max-connections=5
#空闲的连接过期时间,默认为30秒
spring.activemq.pool.idle-timeout=30000
#强制的连接过期时间,与idleTimeout的区别在于:idleTimeout是在连接空闲一段时间失效,而expiryTimeout不管当前连接的情况,只要达到指定时间就失效。默认为0,never 
spring.activemq.pool.expiry-timeout=0

pom.xml也要加入依赖包,否则启动报JmsMessagingTemplate注入失败 。

		<dependency>
		    <groupId>org.apache.activemq</groupId>
		    <artifactId>activemq-pool</artifactId>
		</dependency>

完美解决。

猜你喜欢

转载自my.oschina.net/booktao/blog/1610097