mysql 8小时问题

前段时间做项目的时候遇到了连接mysql数据每间隔一段时间不连接数据库,就会连接不上的问题,特别记录一下,这个问题是由于mysql存在一个8小时问题,默认情况下当连接空闲8个小时后,mysql数据库就会自动断开该连接,而这时我们的连接池还以为连接未断开可以正常使用,所以这个时候就会出现一个8小时问题,当遇到这个问题的时候我们有一下三种方案可以解决该问题:

 

1、增加 MySQL 的 wait_timeout 属性的值。
修改 /etc/mysql/my.cnf 文件,在 [mysqld] 节中设置:

# Set a connection to wait 8 hours in idle status.
wait_timeout = 86400

 

但是这个不能根除,不是很建议大家如此修改

 

2、减少连接池内连接的生存周期,使之小于上一项中所设置的 wait_timeout 的值。

修改 c3p0 的配置文件,设置:

# How long to keep unused connections around(in seconds)
# Note: MySQL times out idle connections after 8 hours(28,800 seconds)
# so ensure this value is below MySQL idle timeout
cpool.maxIdleTime=25200

在 Spring 的配置文件中:

[xhtml] view plain copy

  1. <bean id="dataSource"  
  2.      class="com.mchange.v2.c3p0.ComboPooledDataSource">  
  3.     <property name="maxIdleTime" value="${cpool.maxIdleTime}" />  
  4.     <!-- other properties -->  
  5. </bean>  

 

3、定期使用连接池内的连接,使得它们不会因为闲置超时而被 MySQL 断开。

修改 c3p0 的配置文件,设置:

# Prevent MySQL raise exception after a long idle time
cpool.preferredTestQuery='SELECT 1'
cpool.idleConnectionTestPeriod=18000
cpool.testConnectionOnCheckout=true

修改 Spring 的配置文件:

 

[xhtml] view plain copy

  1. <bean id="dataSource"  
  2.        class="com.mchange.v2.c3p0.ComboPooledDataSource">  
  3.     <property name="preferredTestQuery"  
  4.            value="${cpool.preferredTestQuery}" />  
  5.     <property name="idleConnectionTestPeriod"  
  6.            value="${cpool.idleConnectionTestPeriod}" />  
  7.     <property name="testConnectionOnCheckout"  
  8.            value="${cpool.testConnectionOnCheckout}" />  
  9.     <!-- other properties -->  
  10. </bean>   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值