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>
完美解决。