当前位置:首页 > 开发 > 数据库 > 正文

Hibernate连接Mysql的8小时问题

发表于: 2014-05-03   作者:alleni123   来源:转载   浏览次数:
摘要: 这个问题估计是用mysql建立网站都会碰到的。 每天早上起来打开网页, 就会看到这个问题。。 原因是mysql有一个time_out全局值, 这个值是28800, 也就是28800秒,正好是8小时。8个小时之后会断开连接, 然后jdbc的Connection就需要重新连接才行。 在mysql中运行:show global variables like 'wait_timeout';就可以
这个问题估计是用mysql建立网站都会碰到的。
每天早上起来打开网页, 就会看到这个问题。。

原因是mysql有一个time_out全局值, 这个值是28800, 也就是28800秒,正好是8小时。8个小时之后会断开连接, 然后jdbc的Connection就需要重新连接才行。
在mysql中运行:show global variables like 'wait_timeout';就可以看到该数值。

问题重现
首先我们可以修改一下mysql的配置文件,来重现一下这个错误。
[mysqld]
wait_timeout=20
interactive_timeout=20


这次打开网页,只要过20秒, 刷新请求数据库的页面,就会看到这个错误了。
   Could not open Hibernate Session for transaction; nested exception is org.hibernate.TransactionException: JDBC begin transaction failed:
Caused by:

org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.TransactionException: JDBC begin transaction failed:


再次刷新页面就能打开。



解决方案

此方案针对dbcp.

http://blog.csdn.net/quickgu/article/details/7179023
 validationQuery = "SELECT 1"  
        testWhileIdle = "true"    
        timeBetweenEvictionRunsMillis = "10"  
        minEvictableIdleTimeMillis = "10"
        testOnBorrow = "true"/>

这里设置为10, 也就是mysql连接过期的时间的一半。
这样就会在mysql连接过期之前重新获取连接。

具体部署的时候, 改为小于28800的值就行了。

Hibernate连接Mysql的8小时问题

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
今天用了一下java的数据库持久化-业务的hibernate框架。下面给出hibernate 连接mysql数据库示例 建
nodejs + redis/mysql 连接池问题 需不需要连接池 连接池的作用主要是较少每次临时建立连接所带来的
Mysql:远程连接及用户权限问题 今天开发程序,新建用户后,从本机连接服务器时报异常: 1103 - hos
1.首先在weblogic目录中加入mysql的jar包:mysql-connector-java-5.1.7-bin.jar放入到weblogic目录
如题这个问题还是让人比较揪心的。网上也有不少答案,五花八门,不知道谁对谁错。个人认为有几篇文
1.删除多余的自编译的内核 每次Debian发布内核更新,总是有某些内核选项跟自己的硬件不配套,要自己
最近在学习R语言的数据分析,由于数据存在Mysql中,需要用R语言访问Mysql,配置操作参考下文: http
1. 下载安装JBossTools eclipse的插件 http://www.jboss.org/tools/download/ 也可以只安装 Update
解释名词: 1、内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2、外连接: 包括 (1)
package test; import java.util.List; import org.hibernate.HibernateException; import org.hibe
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号