视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySql8小时重连有关问题
2020-11-09 13:33:59 责编:小采
文档


MySql 8小时重连问题 学习笔记,转自: http://blog.csdn.net/sunguangran/article/details/6303947 http://hi.baidu.com/shluxzslnjbhlyr/item/905c3283c1b9352e0f81c7 ? MySql 8小时问题 MySQL 的默认设置下,当一个连接的空闲时间超过8小时后,MySQL 就

MySql 8小时重连问题

学习笔记,转自:http://blog.csdn.net/sunguangran/article/details/6303947

http://hi.baidu.com/shluxzslnjbhlyr/item/905c3283c1b9352e0f81c7

?

MySql 8小时问题

MySQL 的默认设置下,当一个连接的空闲时间超过8小时后,MySQL 就会断开该连接,而 c3p0 连接池则以为该被断开的连接依然有效。在这种情况下,如果客户端代码向 c3p0 连接池请求连接的话,连接池就会把已经失效的连接返回给客户端,客户端在使用该失效连接的时候即抛出异常。

?

这就是传说中的 mySql 8小时问题。


解决这个问题的办法有三种:
1. 增加 MySQL 的 wait_timeout 属性的值。
修改 /etc/mysql/my.cnf 文件,在 [mysqld] 节中设置:

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

相关参数,红色部分
mysql> show variables like '%timeout%';
+--------------------------+-------+
| Variable_name??????????? | Value |
+--------------------------+-------+
| connect_timeout????????? | 5???? |
| delayed_insert_timeout?? | 300?? |
| innodb_lock_wait_timeout | 50??? |
| interactive_timeout????? | 28800 |
| net_read_timeout???????? | 30??? |
| net_write_timeout??????? | 60??? |
| slave_net_timeout??????? | 3600 |
| wait_timeout???????????? | 28800 |
+--------------------------+-------+?????????
同一时间,这两个参数只有一个起作用。到底是哪个参数起作用,和用户连接时指定的连接参数相关,缺省情况下是使用wait_timeout。我建议是将这两个参数都修改,以免引起不必要的麻烦。

这两个参数的默认值是8小时(60*60*8=28800)。

测试将这两个参数改为0,结果出人意料,系统自动将这个值设置为28800 。

换句话说,不能将该值设置为永久。
将这2个参数设置为1年(60*60*24*365=31536000)

总不至于一年都不用这个链接吧?
set interactive_timeout=31536000;
set wait_timeout=31536000;

结果:


?

wait_timeout 的设置出现警告,再看看设置后的结果


?

也就是说wait_timeout的最大值只允许2147483 (24天左右)

。。。

?

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 的配置文件中:

???? class="com.mchange.v2.c3p0.ComboPooledDataSource">
????
????

?

?

3. 定期使用连接池内的连接,使得它们不会因为闲置超时而被 MySQL 断开。
修改 c3p0 的配置文件,设置:

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

修改 Spring 的配置文件:

???? class="com.mchange.v2.c3p0.ComboPooledDataSource">???????????? value="${cpool.preferredTestQuery}" />???????????? value="${cpool.idleConnectionTestPeriod}" />???????????? value="${cpool.testConnectionOnCheckout}" />???? 注:网上所说的 设置 "autoReconnect=true" 的方法,本人测试无效,又看到说这个方法只有mysql4以前的版本才适用......

下载本文
显示全文
专题