作为初学程序编写的屌丝,我一直认为自己电脑可以运行就是完成任务了。但是部署在服务器上隔夜后就会报错,数据库连接不到的错误。
问题:
MySQL默认是自动关闭空闲超过8小时的连接,而C3P0并不知道该connection已经失效,如果这时有Client请求connection,C3P0将该失效的Connection提供给Client,将会造成异常。重启Tomcat操作会使C3P0重新建立和数据库的连接池,且池内的连接都是有效的连接。
解决方法:c3p0要在8小时内关闭不使用的连接。这需要修改其中的一些配置参数,主要是maxIdleTime和idleConnectionTestPeriod。这两个参数的值要小于28800秒。
解决方案:
做一下配置
<!-- 每次都验证连接是否可用 -->
<property name="hibernate.c3p0.validate">true</property>
<!-- 检查连接池中所有空闲连接的间隔时间,单位为秒(要注意的是MySQL的自动关闭空闲超过8小时连接的机制) -->
<property name="hibernate.c3p0.idle_test_period">18000</property>
<!-- 连接的最大空闲时间,25000秒内未使用则连接被丢弃。单位为秒(要注意的是MySQL的自动关闭空闲超过8小时连接的机制) -->
<property name="hibernate.c3p0.timeout">25000</property>
这样8小时内连接就会被断开,不会把无用的连接进行发送而出现错误。
重新启懂tomcat正常运行,然后把自己电脑的时间往后修改一天,在访问,也不会有错误。这样,mysql 8 小时错误就解决了。