MySQL官网API : https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_wait_timeout

【1】分别是什么

① interactive_timeout

官网说明如下:MySQL官网地址

这里写图片描述

MySQL服务器关闭交互式连接前等待的秒数。交互式客户端定义为在mysql_real_connect()中使用CLIENT_INTERACTIVE选项的客户端。参数默认值:28800秒(8小时)


② wait_timeout

这里写图片描述

MySQL服务器关闭非交互连接之前等待的秒数。在会话启动时,根据全局wait_timeout值或全局interactive_timeout值初始化会话wait_timeout值,取决于客户端类型–由mysql_real_connect()的连接选项CLIENT_INTERACTIVE定义。参数默认值:28800秒(8小时)。

什么是交互连接,什么是非交互连接?

通过MySQL 客户端连接数据库的是交互会话,通过jdbc等程序连接数据库的是非交互会话。


【2】继承关系

① 单独修改全局interactive_timeout

set GLOBAL interactive_timeout=1000;

分别查看全局、会话变量值:

show GLOBAL VARIABLES like '%timeout%';
show  VARIABLES like '%timeout%';

这里写图片描述

分析如下:

在交互模式下,session和global级别的 interactive_timeout 继承了 interactive_timeout global的值。而 wait_timeout 的值,session级别继承了interactive_timeout。global级别的wait_timeout 则不受影响 。


② 设置session级别的interactive_timeout

set interactive_timeout = 1100;

这里写图片描述

分析如下:

无论全局还是会话级别的wait_timeout值并不受session级别的interactive_timeout的值的影响。


③ 同时设置全局值,且不同

set GLOBAL interactive_timeout = 1300;
set GLOBAL wait_timeout = 1400;

查看全局变量值:

show GLOBAL VARIABLES like '%timeout%';

这里写图片描述
查看会话变量值:

show  VARIABLES like '%timeout%';

这里写图片描述


分析如下:

session级别的wait_timeout 继承global 级别的 interactive_timeout 的值。 global级别的wait_timeout 则不受影响。在没有改变 interactive_timeout的值的情况下,去修改wait_timeout的值, 结果无效。

如上是交互式连接测试下结果:交互式连接的wait_timeout 继承于global的interactive_timeout。

而非交互是连接结果如下:非交互式连接的wait_timeout继承于global的wait_timeout。

【3】项目异常与值设置

项目使用程序连接数据库,那么就属于非交互连接了,就需要着重考虑如何设置wait_timeout值。

常见问题如下:

① The last packet successfully received from the server was 23,579 milliseconds ago. The last packet sent successfully to the server was 0 milliseconds ago.
Caused by: java.io.EOFException: Can not read response from server. Expected to read 4 bytes, read 0 bytes before connection was unexpectedly lost.

② MySQL server has gone away

值设置

wait_timeout默认值为28800,大小需要根据项目来定。
wait_timeout过大有弊端,其体现就是MySQL里大量的SLEEP进程无法及时释放。
过小容易遇到MySQL server has gone away ,死锁等待等问题。

【4】总结

  1. 控制连接最大空闲时长的wait_timeout参数。
  2. 对于非交互式连接,类似于jdbc连接,wait_timeout的值继承自服务器端全局变量wait_timeout。
    对于交互式连接,类似于mysql客户单连接,wait_timeout的值继承自服务器端全局变量interactive_timeout
  3. 判断一个连接的空闲时间,可通过show processlist输出中Sleep状态的时间。
  4. 超时时间只对非活动状态的connection进行计算。
  5. 超时时间只以session级别的wait_timeout 为超时依据,global级别只决定session初始化时的超时默认值。
Logo

更多推荐