数据库连接突然失败,必须重启服务器的解决办法

时间:2020-12-15 09:21:41
  我系统中用到了 spring+hibernate 的框架 , 如果和数据库连接断了 , 而马上数据库又能用了 ,hibernate 不会重新获得连接了 , 如何才能再初始化 sessionFactory 呀,因为 hibernate 默认的连接池是 dbcp ,但是 dbcp 不支持异常重新连接,所以出现这个问题。解决办法:

改用C3P0连接池,这个连接池会自动处理数据库连接被关闭的情况。要使用C3P0很简单,先从Hibernate里把c3p0-0.8.3.jar复制到项目的lib目录中,再在hibernate.properties里去掉hibernate.c3p0开头的那些属性的注释(使用缺省值或自己需要的数值),这样Hibernate就会自动使用C3P0代替内置的连接池了。到目前为止前面的问题没有再出现过。