Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: The last packet successfully received from the server was48477 seconds ago.
解决方法:
这是一个标准的servlet/tomcat网络应用,后台使用mysql数据库。问题是待机一晚上后,第二天早上第一次登录总是失败。mysql5将其连接的等待时间(wait_timeout)默认缺省为8小时。在客户端查看其值:
mysql﹥
mysql﹥ show global variables like ‘wait_timeout’;
+—————+———+
| Variable_name | Value |
+—————+———+
| wait_timeout | 28800 |
+—————+———+
1 row in set (0.00 sec)
28800 seconds,也就是8小时。
如果在wait_timeout秒期间内,数据库连接(java.sql.Connection)一直处于等待状态,mysql5就将该连接关闭。这时,你的Java应用的连接池仍然合法地持有该连接的引用。当用该连接来进行数据库操作时,就碰到上述错误。这解释了为什么我的程序第二天不能登录 的问题。
解决办法有三种:
1、修改MYSQl的配置文件“my.cnf”(Windows中为“my.ini”),延长“wait_timeout”。
2、修改项目中c3p0的配置文件,添加或修改属性“maxIdleTime”,使之小于Mysql的“wait_timeout”值。
3、定时使用连接池中的连接