专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

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

问题出现原因

show global variables like '%wait_timeout';    --可以查看数据库空闲等待时间,默认8小时,最大2147483,接近24天

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

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]后面添加

wait_timeout = 1814400
interactive_timeout = 1814400 --单位都是秒,通过show GLOBAL VARIABLEs like 'wait_timeout'  可以查看wait_timeout的值

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

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

1、 c3p0配置(单位秒):

<!-- 
配置C3P0连接池属性 
注:若测试配置成功:mysql:show processlist 连接记录数=连接池的最小连接数+3(非连接)
       若配置失败: 连接记录数=3(非连接)+1(当前连接)
-->
<property name="hibernate.conne ction.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<!--连接池的最小连接数,默认为:3-->
<property name="hibernate.c3p0.min_size">4</property>
<!--连接池的最大连接数,默认值: 15-->
<property name="hibernate.c3p0.max_size">30</property>
<!--连接超时时间-->
<property name="hibernate.c3p0.timeout">1800</property>
<!--每隔多少秒检测连接是否可正常使用,这个值要小于MySQL的wait_timeout(默认为8小时)时间,默认0(这是解决以上问题的关键)-->
<property name="hibernate.c3p0.idle_test_period">20</property>
<!--当池中的连接耗尽的时候,一次性增加的连接数量,默认为 3-->
<property name="hibernate.c3p0.acquire_increment">1</property>
<!-- 是否验证,检查连接 -->
<property name="hibernate.c3p0.validate">false</property>
<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。默认值: 0 -->
<property name="maxIdleTime">60</property>
<!-- 初始化连接池中的连接数,取值应在最小连接数与最大连接数之间,默认为3-->
<property name="initialPoolSize">2</property>

测试是否问题已解决

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

  • 设置set global wait_timeout=10,即10秒后数据库断开连接
  • 进行测试,不久发现出现上述异常(通常我们遇到的情况,只是我们一般是八小时后才出现,这里设置为十秒)

1、 使用c3p0,配置上面属性:<property name="hibernate.c3p0.idle_test_period">20</property>

  • 程序开始运行,在数据库输入show PROCESSLIST; 显示当前连接:连接记录数=3(非连接)+4(当前连接),说明配置成功
  • 程序运行大概10S出现上述问题(不出意料),此时输入show PROCESSLIST; 显示当前连接:连接记录数=3(非连接)+0(当前连接),表示c3p0已断开
  • 程序运行大概20S后,输入show PROCESSLIST; 显示当前连接:连接记录数=3(非连接)+4(当前连接),表示c3p0已连接上,往此复返…..

1、 配置上面属性:<property name="hibernate.c3p0.idle_test_period">8</property>,程序运行起来,一直没有再出现过问题了。嘿嘿

建议

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

文章永久链接:https://tech.souyunku.com/19423

未经允许不得转载:搜云库技术团队 » Mysql空闲等待时间导致的异常解决方案

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们