mysql 空闲等待时间_Mysql空闲等待时间导致的异常解决方案

问题出现原因

即某程序连接数据库,若超过该时间,则会断开连接,可能出现:

1、com.mysql.jdbc.exceptions.MySQLNonTransientConnectionException: Connection.close() has already been called. Invalid operation in this state.

2、java.net.SocketException: Software caused connection abort: recv failed

3、其他错误

解决方案

1、 如果是MySQL5以前的版本,需要修改连接池配置中的URL,添加autoReconnect=true

2、 如果是MySQL5 以后的版本,需要修改my.cnf(或者my.ini)文件,在[mysqld]后面添加

1、 使用sql: set global wait_timeout=1814400来修改全局变量,如果只是修改当前会话的空闲等待时间,可以使用session代替global

以上方法都不是最好的解决方案,因为到了设置的最大时间,数据库还是该报错还是报错,所以,推荐使用c3p0连接池,可以很好解决

1、 c3p0配置(单位秒):

测试是否问题已解决

1、 不使用c3p0,程序跑起来之后,在数据库输入show PROCESSLIST; 显示当前连接:连接记录数=3(非连接)+1(当前连接)(正常情况)

设置set global wait_timeout=10,即10秒后数据库断开连接

进行测试,不久发现出现上述异常(通常我们遇到的情况,只是我们一般是八小时后才出现,这里设置为十秒)

1、 使用c3p0,配置上面属性:20

程序开始运行,在数据库输入show PROCESSLIST; 显示当前连接:连接记录数=3(非连接)+4(当前连接),说明配置成功

程序运行大概10S出现上述问题(不出意料),此时输入show PROCESSLIST; 显示当前连接:连接记录数=3(非连接)+0(当前连接),表示c3p0已断开

程序运行大概20S后,输入show PROCESSLIST; 显示当前连接:连接记录数=3(非连接)+4(当前连接),表示c3p0已连接上,往此复返…..

1、 配置上面属性:8,程序运行起来,一直没有再出现过问题了。嘿嘿

建议

推荐是将数据库的wait_timeout设置到24小时即86400,然后使用c3p0,设置时间小于86400,自己视情况而定。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值