zoukankan      html  css  js  c++  java
  • 使用druid连接池的超时回收机制排查连接泄露问题

    在工程中使用了druid连接池,运行一段时间后系统出现异常:

    1. Caused by: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60009, active 50  
    2.                 at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:80)  
    3.                 at org.springframework.jdbc.support.JdbcUtils.extractDatabaseMetaData(JdbcUtils.java:280)  
    4.                 ... 64 more  
    5. Caused by: com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 60000, active 50  
    6.                 at com.alibaba.druid.pool.DruidDataSource.getConnectionInternal(DruidDataSource.java:1071)  
    7.                 at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:898)  
    8.                 at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4544)  


    mysql数据库最大连接数设置为500,使用客户端能正常连接。连接数被未被占满。

    分析原因应该是程序中有地方连接未关闭造成的。那如何来定呢?使用druid连接池的超时回收机制,在配置中增加以下内容:

    1. <!-- 超过时间限制是否回收 -->  
    2. <property name="removeAbandoned" value="true" />  
    3. <!-- 超时时间;单位为秒。180秒=3分钟 -->  
    4. <property name="removeAbandonedTimeout" value="180" />  
    5. <!-- 关闭abanded连接时输出错误日志 -->  
    6. <property name="logAbandoned" value="true" />     


    运行程序,当连接超过3分钟后会强制进行回收,并输出异常日志。

    1. 2014-10-13 16:02:28,919 ERROR [com.alibaba.druid.pool.DruidDataSource] - <abandon connection, open stackTrace  
    2.         at java.lang.Thread.getStackTrace(Thread.java:1567)  
    3.         at com.alibaba.druid.pool.DruidDataSource.getConnectionDirect(DruidDataSource.java:995)  
    4.         at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4544)  
    5.         at com.alibaba.druid.filter.stat.StatFilter.dataSource_getConnection(StatFilter.java:661)  
    6.         at com.alibaba.druid.filter.FilterChainImpl.dataSource_connect(FilterChainImpl.java:4540)  
    7.         at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:919)  
    8.         at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:911)  
    9.         at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:98)  
    10.           
    11.         at cn.org.xxx.xxx.xxx.PaginationInterceptor.intercept(PaginationInterceptor.java:96)  
    12.           
    13.         at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:60)  
    14.         at com.sun.proxy.$Proxy59.query(Unknown Source)  
    15.         at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:108)  


    很清楚地看到是在哪里打开的连接未关闭一直在占有。

    此配置项会影响性能,只在排查的时候打开。系统运行时最好关闭。

  • 相关阅读:
    Saslauthd服务实现SMTP发信认证
    携程Apollo一键编译脚本+部署实现
    Shell编程总结
    Oracle数据库的安装 【超详细的文图详解】
    区块链技术开发导向 聊应用及正确发展方向
    单机Qps上限是多少?
    Linux运维第二课----Linux发展史、环境准备
    JAVA_新建一个方法并且求三个数中的最大值
    iOS视频边下载边播放
    Python从零搭建Conf_Web配置管理平台
  • 原文地址:https://www.cnblogs.com/chenzc/p/6640218.html
Copyright © 2011-2022 走看看