开发者社区> 问答> 正文

Druid 连接mysql 报skip not validate connection,什么情况?

2016-5-06 15:31:53 -2722434 [http-apr-8090-exec-4] DEBUG   - skip not validate connection.
2016-5-06 15:32:12 -2741345 [http-apr-8090-exec-4] DEBUG   - skip not validate connection.

用的druid关联连接池,数据库是mysql,一段时间不用之后就会报这个错误。之前有人说是mysql系统的问题。我从window换成linux也是这样。下面是我的配置文件

url:jdbc:mysql://xxx.xx.xxx.xxx:3306/XXX?Unicode=true&characterEncoding=utf8&autoReconnect=true
driverClassName:com.mysql.jdbc.Driver
username:root
password:123456
        
filters:stat
    
maxActive:100
initialSize:10
maxWait:60000
minIdle:20
maxIdle:100
    
timeBetweenEvictionRunsMillis:60000
minEvictableIdleTimeMillis:300000
    
validationQuery:SELECT 'x'
testWhileIdle:true
testOnBorrow:false
testOnReturn:false
 
maxOpenPreparedStatements:20
removeAbandoned:true
removeAbandonedTimeout:180
logAbandoned:true

spring里面的配置

<!-- 阿里 druid数据库连接池 -->
    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
        destroy-method="close">
        <!-- 数据库基本信息配置 -->
        <property name="url" value="${url}" />
        <property name="username" value="${username}" />
        <property name="password" value="${password}" />
        <property name="driverClassName" value="${driverClassName}" />
        <property name="filters" value="${filters}" />
        <!-- 最大并发连接数 -->
        <property name="maxActive" value="${maxActive}" />
        <!-- 初始化连接数量 -->
        <property name="initialSize" value="${initialSize}" />
        <!-- 配置获取连接等待超时的时间 -->
        <property name="maxWait" value="${maxWait}" />
        <!-- 最小空闲连接数 -->
        <property name="minIdle" value="${minIdle}" />
        <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
        <property name="timeBetweenEvictionRunsMillis" value="${timeBetweenEvictionRunsMillis}" />
        <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
        <property name="minEvictableIdleTimeMillis" value="${minEvictableIdleTimeMillis}" />
        <property name="validationQuery" value="${validationQuery}" />
        <property name="testWhileIdle" value="${testWhileIdle}" />
        <property name="testOnBorrow" value="${testOnBorrow}" />
        <property name="testOnReturn" value="${testOnReturn}" />
        <property name="maxOpenPreparedStatements" value="${maxOpenPreparedStatements}" />
        <!-- 打开removeAbandoned功能 -->
        <property name="removeAbandoned" value="${removeAbandoned}" />
        <!-- 1800秒,也就是30分钟 -->
        <property name="removeAbandonedTimeout" value="${removeAbandonedTimeout}" />
        <!-- 关闭abanded连接时输出错误日志 -->
        <property name="logAbandoned" value="${logAbandoned}" />
    </bean>

是不是哪里配错了?为什么会出现这个情况? 数据库是远程服务器上的数据库,网络绝对没有问题。目前能排除的问题有网络、数据库(换过低版本,高版本)、系统(window、linux)、所以这个问题应该出现在程序上,应该是我配置文件的问题。求大神解答。。

展开
收起
落地花开啦 2016-06-03 13:39:05 13805 0
2 条回答
写回答
取消 提交回答
  • 这个人很懒,除了颜值和才华什么也没留下。

    楼主解决了吗,我看了下源码知道什么原因,但不知道这搞啊,不启用testOnBorrow?

    2019-07-17 19:26:30
    赞同 展开评论 打赏
  • 喜欢技术,喜欢努力的人

    数据库服务器的防火墙会自动中断一段时间未活动的TCP连接,相当于中断了数据库物理连接,Druid连接池中维护的数据库逻辑连接尝试与数据库服务器进行被服务器单方面中断的连接进行TCP通信,会失败(Druid把异常捕获了。只返回false,然后Druid再新开一个TCP连接),重要的是这个失败的过程耗时很长,因此这种情况下给用户的体验就是请求长时间未得到返回。

    2019-07-17 19:26:30
    赞同 1 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
One Box: 解读事务与分析一体化数据库 HybridDB for MySQL 立即下载
One Box:解读事务与分析一体化数据库HybridDB for MySQL 立即下载
如何支撑HTAP场景-HybridDB for MySQL系统架构和技术演进 立即下载

相关镜像