Druid 连接mysql 报skip not validate connection,什么情况?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

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

2016-06-03 13:39:05 12113 2
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)、所以这个问题应该出现在程序上,应该是我配置文件的问题。求大神解答。。

取消 提交回答
全部回答(2)
  • ryouii
    2019-07-17 19:26:30

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

    0 0
  • 落地花开啦
    2019-07-17 19:26:30

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

    1 0
添加回答
相关问答

1

回答

MySQL体系结构Connection Pool指什么?

2021-11-19 13:05:29 95浏览量 回答数 1

0

回答

java链接mysql开启事务后出现 could open jdbc connection异常

2021-10-26 19:24:16 671浏览量 回答数 0

1

回答

many connection errors - mysql报错

2020-05-28 09:20:23 258浏览量 回答数 1

4

回答

navicat连接轻量服务器mysql报错network error: connection timeout

2018-10-04 21:31:14 10780浏览量 回答数 4

3

回答

windows下mysql运行sql文件提示lost connection to mysql

2017-03-01 16:04:14 2736浏览量 回答数 3

1

回答

Druid 连接mysql 报skip not validate connection

2016-06-15 15:56:51 9119浏览量 回答数 1

1

回答

自建的 MySQL 迁移至 RDS MySQL 可以通过哪个产品实现应用不停服务的情况下,平滑完成数

2022-11-02 15:10:04 25浏览量 回答数 1

1

回答

RDS MySQL 实例支持哪两种数据库账号?

2022-11-02 15:02:34 36浏览量 回答数 1

1

回答

RDS MySQL 实例支持的普通账号拥有哪些权限?

2022-11-02 12:41:19 48浏览量 回答数 1

1

回答

RDS MySQL 实例支持的高权限账号拥有哪些权限?

2022-11-02 12:41:19 55浏览量 回答数 1
+关注
落地花开啦
喜欢技术,喜欢努力的人
文章
问答
问答排行榜
最热
最新
相关电子书
更多
好的 MySQL 兼容可以做到什么程度
立即下载
MySQL 5.7让优化更轻松
立即下载
PostgresChina2018_张启程_为什么我们抛弃MongoDB和MySQL,选择PgSQL
立即下载