首页 > 代码库 > 再淡spring jdbc 连接池断开重连设置
再淡spring jdbc 连接池断开重连设置
先看一段错误日志:
### Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed. ### The error may exist in file …………] ### The error may involve ..... ### The error occurred while executing a query ### Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed. ; SQL []; No operations allowed after connection closed.; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: No operations allowed after connection closed.
网上一搜,解决办法一大堆,基本配置如下:
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value=http://www.mamicode.com/"${jdbc.driverClassName}" />"font-family:Arial,Helvetica,sans-serif">每5分钟检测空闲连接超过10分钟的连接--> <property name="timeBetweenEvictionRunsMillis" value=http://www.mamicode.com/"300000" /> >
可是,这就够了吗?
一开始放到自己的环境上是没有用的,还是报错了。
继续努力,最后是解决了。
第一要理解连接池的各项配置(上面)
第二是要知道mysql中wait_timeout的设置
两点结合才能确定连接池在项目中的合理正确配置。
如果wait_timeout设置成很大一个值,例如一年,那么上面的配置很多情况下都是正确的。
如果wait_timeout设置成很小,如1分钟,那么上面的配置是有问题的。因为服务器1分钟就把空闲连接断开了,客户端过了5分钟再去检查连接情况,那有什么意义?先前就是没理解被误导了,把timeBetweenEvictionRunsMillis设置了一个比较大的值,所以一直有问题。包括所说的8小时问题也是源于此(mysql数据库默认是空闲8小时断开)。
我的原因是mysql的wait_timeout的值设置小了,而客户端检测的间隔时间过大。
正确的做法是:
连接池配置中的timeBetweenEvictionRunsMillis和
minEvictableIdleTimeMillis的
时间小于或者等于mysql数据库中wait_timeout的时间。再淡spring jdbc 连接池断开重连设置
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。