Hibernate+Mysql 隔日连接池断开

问题原因

MySQL默认是自动关闭空闲超过8小时的连接,而C3P0并不知道该connection已经失效,如果这时有Client请求connection,C3P0将该失效的Connection提供给Client,将会造成异常。重启Tomcat操作会使C3P0重新建立和数据库的连接池,且池内的连接都是有效的连接。

解决方法

c3p0要在8小时内关闭不使用的连接。这需要修改其中的一些配置参数,主要是maxIdleTime和idleConnectionTestPeriod。这两个参数的值要小于28800秒。

建议配置如下


"hibernate.c3p0.validate">true

"hibernate.c3p0.idle_test_period">18000

"hibernate.c3p0.timeout">25000

你可能感兴趣的:(软件工程)