我是靠谱客的博主 粗犷大叔,最近开发中收集的这篇文章主要介绍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

最后

以上就是粗犷大叔为你收集整理的c3p0 服务启动获取连接超时_解决C3P0连接MySQL链接失效的问题的全部内容,希望文章能够帮你解决c3p0 服务启动获取连接超时_解决C3P0连接MySQL链接失效的问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部