当程序存在缺陷时,申请的连接忘记关闭,这时候,就存在连接泄漏了。Druid提供了RemoveAbandanded相关配置,用来关闭长时间不使用的连接。例如:

配置

  1. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
  2. ... ...
  3. <property name="removeAbandoned" value="true" /> <!-- 打开removeAbandoned功能 -->
  4. <property name="removeAbandonedTimeout" value="1800" /> <!-- 1800秒,也就是30分钟 -->
  5. <property name="logAbandoned" value="true" /> <!-- 关闭abanded连接时输出错误日志 -->
  6. ... ...
  7. </bean>

配置removeAbandoned对性能会有一些影响,建议怀疑存在泄漏之后再打开。在上面的配置中,如果连接超过30分钟未关闭,就会被强行回收,并且日志记录连接申请时的调用堆栈。

内置监控页面查看未关闭连接堆栈信息

当removeAbandoned=true之后,可以在内置监控界面datasource.html中的查看ActiveConnection StackTrace属性的,可以看到未关闭连接的具体堆栈信息,从而方便查出哪些连接泄漏了。

web应用

如果你的应用配置了WebStatFilter: https://github.com/alibaba/druid/wiki/%E9%85%8D%E7%BD%AE_%E9%85%8D%E7%BD%AEWebStatFilter在内置监控页面weburi-detail.html中,查看JdbcPoolConnectionOpenCount和JdbcPoolConnectionCloseCount属性,如果不相等,就是泄漏了。