日期:2014-05-16 浏览次数:20699 次
之前在使用SSH开发项目的时候遇到了一个很奇怪的问题,部署到服务器上,运行一段时间后系统就崩溃了。
出现错误:org.hibernate.exception.JDBCConnectionException: could not execute query
在后在百度上查了下资料发现了问题所在,原来这个是传说中的8小时问题— —。
Mysql服务器默认的“wait_timeout”是8小时,也就是说一个connection空闲超过8个小时,Mysql将自动断开该 connection。这就是问题的所在,在Hibernate默认连接池中的connections如果空闲超过8小时,Mysql将其断开,而Hibernate默认连接池并不知道该connection已经失效,如果这时有 Client请求connection,Hibernate默认连接池将该失效的Connection提供给Client,将会造成上面的异常。
修改 /etc/mysql/my.cnf 文件,在 [mysqld] 节中设置: