再淡spring jdbc 连接池断开重连设置
2014-11-14 18:05
483 查看
先看一段错误日志:
这个是连接池断开后(网络、数据库断开),没有确认池里的连接继续可用的情况下,去操作数据库。
网上一搜,解决办法一大堆,基本配置如下:
可是,这就够了吗?
一开始放到自己的环境上是没有用的,还是报错了。
继续努力,最后是解决了。
第一要理解连接池的各项配置(上面)
第二是要知道mysql中wait_timeout的设置
两点结合才能确定连接池在项目中的合理正确配置。
如果wait_timeout设置成很大一个值,例如一年,那么上面的配置很多情况下都是正确的。
如果wait_timeout设置成很小,如1分钟,那么上面的配置是有问题的。因为服务器1分钟就把空闲连接断开了,客户端过了5分钟再去检查连接情况,那有什么意义?先前就是没理解被误导了,把timeBetweenEvictionRunsMillis设置了一个比较大的值,所以一直有问题。包括所说的8小时问题也是源于此(mysql数据库默认是空闲8小时断开)。
我的原因是mysql的wait_timeout的值设置小了,而客户端检测的间隔时间过大。
正确的做法是:
连接池配置中的timeBetweenEvictionRunsMillis和
时间小于或者等于mysql数据库中wait_timeout的时间。
### 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="${jdbc.driverClassName}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> <!-- 队列中的最小等待数 --> <property name="minIdle" value="${jdbc.minIdle}"></property> <!-- 队列中的最大等待数 --> <property name="maxIdle" value="${jdbc.maxIdle}"></property> <!-- 最长等待时间,单位毫秒 --> <property name="maxWait" value="${jdbc.maxWait}"></property> <!-- 最大活跃数 --> <property name="maxActive" value="${jdbc.maxActive}"></property> <property name="initialSize" value="${jdbc.initialSize}"></property> <property name="validationQuery" value="select 1"/> <property name="testOnBorrow" value="false"/> <property name="testWhileIdle" value="true"/> <property name="testOnReturn" value="false"/> <property name="numTestsPerEvictionRun" value="${jdbc.maxActive}"/> <!-- 5 min 每5分钟检测空闲连接超过10分钟的连接--> <property name="timeBetweenEvictionRunsMillis" value="300000" /> <property name="minEvictableIdleTimeMillis" value="600000" /> <property name="removeAbandoned" value="true"/> </bean>
可是,这就够了吗?
一开始放到自己的环境上是没有用的,还是报错了。
继续努力,最后是解决了。
第一要理解连接池的各项配置(上面)
第二是要知道mysql中wait_timeout的设置
两点结合才能确定连接池在项目中的合理正确配置。
如果wait_timeout设置成很大一个值,例如一年,那么上面的配置很多情况下都是正确的。
如果wait_timeout设置成很小,如1分钟,那么上面的配置是有问题的。因为服务器1分钟就把空闲连接断开了,客户端过了5分钟再去检查连接情况,那有什么意义?先前就是没理解被误导了,把timeBetweenEvictionRunsMillis设置了一个比较大的值,所以一直有问题。包括所说的8小时问题也是源于此(mysql数据库默认是空闲8小时断开)。
我的原因是mysql的wait_timeout的值设置小了,而客户端检测的间隔时间过大。
正确的做法是:
连接池配置中的timeBetweenEvictionRunsMillis和
minEvictableIdleTimeMillis的
时间小于或者等于mysql数据库中wait_timeout的时间。
相关文章推荐
- 再淡spring jdbc 连接池断开重连设置
- spring配置ibatis的jdbc方式和proxool连接池方式
- Spring2 JDBC 连接池
- Spring中JdbcTemplate结合连接池(c3p0、dbcp、JdbcDateSupport)及配置properties
- Spring+SpringMVC+MyBatis+easyUI整合优化篇(九)数据层优化-jdbc连接池简述、druid简介
- Spring学习-25:Spring中的JDBC Template(JDBC模板):设置参数到属性文件
- Tomcat 6 通过 JDBC 连接池连接 SQL Server 2000 和 MySQL 5 的设置
- spring之jdbc的DataSource的设置
- [置顶] dubbo2.5-spring4-mybastis3.2-springmvc4-mongodb3.4-redis3.2整合(二)之 JDBC连接池、监控组件 Druid
- Spring的数据库操作---- Spring框架对JDBC的整合---- 初始化连接池数据源对象
- springboot 连接池wait_timeout超时设置
- 在JDBC和Spring中使用proxool连接池
- Hibernate连接池断开自动重连
- 应知道的数据库连接池DBCP配置及JDBC超时设置
- spring — jdbc 配置文件的设置
- 在Red5中使用Spring-JDBC配置MySql连接池
- Spring -- spring 中使用jdbc, c3p0连接池, dao概念
- 应知道的数据库连接池DBCP配置及JDBC超时设置
- Java_Jdbc_连接池的testQuery/validationQuery设置
- Spring配置jdbc.properties时数据库用户名设置名称要注意