c3p0 服务启动获取连接超时_解决C3P0连接MySQL链接失效的问题

昨天把一个小项目挂服务器上,测试了项目的运行是可以的。第二天打开项目,一旦打开需要使用数据库的页面直接就挂了。报JDBC EXCEPTION,还提示去修改一个wait_timeout的字段。网上搜了下,这个wait_timeout是管理MySQL链接有效期的变量,可以通过以下语句查出MySQL链接的超时时间。

此处wait_timeout是28800秒,也就是8个小时。

C3P0作为连接池,它的最大的任务就是来管理链接的,可是实际上它并不知道这个链接是否还有效,所以,当MySQL某个链接的建立时间已经超过了wait_timeout的时候,那么这个链接实际上已经不能用了。而C3P0却还不知道,相当于C3P0持有了不能使用的链接。

那么解决这个问题也就有两个思路了。

1.延长MySQL的wait_timeout

2.让C3P0主动去测试持有的链接是否有效

考虑到实际中的应用,第一种思路其实并不是很好,因为C3P0作为连接池,理所应当地管理一切跟链接有关的东西,所以,从第二种思路入手比较合适些。

关于链接失效的问题,C3P0官方文档给出了这样子的解决方式

Begin by setting testConnectionOnCheckout to true and get your application to run correctly and stably. If you are happy with your application's performance, you can stop here! This is the simplest, most reliable form of Connection-tes

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值