先看一段错误日志:
### 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.
这个是连接池断开后(网络、数据库断开)。没有确认池里的连接继续可用的情况下,去操作数据库。
网上一搜,解决的方法一大堆,基本配置例如以下:
但是,这就够了吗?
一開始放到自己的环境上是没实用的,还是报错了。
继续努力,最后是攻克了。
第一要理解连接池的各项配置(上面)
第二是要知道mysql中wait_timeout的设置
两点结合才干确定连接池在项目中的合理正确配置。
假设wait_timeout设置成非常大一个值,比如一年,那么上面的配置非常多情况下都是正确的。
假设wait_timeout设置成非常小,如1分钟,那么上面的配置是有问题的。
由于server1分钟就把空暇连接断开了,client过了5分钟再去检查连接情况,那有什么意义?先前就是没理解被误导了,把timeBetweenEvictionRunsMillis设置了一个比較大的值,所以一直有问题。包含所说的8小时问题也是源于此(mysql数据库默认是空暇8小时断开)。
我的原因是mysql的wait_timeout的值设置小了。而client检測的间隔时间过大。
正确的做法是:
连接池配置中的timeBetweenEvictionRunsMillis和
minEvictableIdleTimeMillis的
时间小于或者等于mysql数据库中wait_timeout的时间。