MySQL中interactive_timeout和wait_timeout的区别

在用mysql客户端对数据库进行操作时,打开终端窗口,如果一段时间没有操作,再次操作时,常常会报如下错误:

ERROR2013(HY000): Lost connection to MySQL server during query

ERROR2006 (HY000): MySQL server has gone away

No connection. Trying to reconnect...

这个报错信息就意味着当前的连接已经断开,需要重新建立连接。

那么,连接的时长是如何确认的?

其实,这个与interactive_timeout和wait_timeout的设置有关。

首先,看看官方文档对于这两个参数的定义

interactive_timeout

默认是28800,单位秒,即8个小时

The number of seconds the server waitsforactivity on an interactive connection before closing it. An interactive clientisdefinedasa client that uses the CLIENT_INTERACTIVE option to mysql_real_connect(). See also wait_timeout.

wait_timeout

默认同样是28800s

The number of seconds the server waitsfor activity on a noninteractive connection before closing it.

On thread startup, the session wait_timeout value isinitializedfromtheglobalwait_timeout value orfromtheglobalinteractive_timeout value, depending on the type of client (asdefined by the CLIENT_INTERACTIVE connect option to mysql_real_connect()). See also interactive_timeout.

根据上述定义,两者的区别显而易见

1> interactive_timeout针对交互式连接,wait_timeout针对非交互式连接。所谓的交互式连接,即在mysql_real_connect()函数中使用了CLIENT_INTERACTIVE选项。

     说得直白一点,通过mysql客户端连接数据库是交互式连接,通过jdbc连接数据库是非交互式连接。 

2> 在连接启动的时候,根据连接的类型,来确认会话变量wait_timeout的值是继承于全局变量wait_timeout,还是interactive_timeout。


下面来测试一下,确认如下问题

1. 控制连接最大空闲时长的是哪个参数。

2. 会话变量wait_timeout的继承问题

Q1:控制连接最大空闲时长的是哪个参数

A1:wait_timeout

验证

只修改wait_timeout参数

mysql>selectvariable_name,variable_valuefrominformation_schema.session_variableswherevariable_namein('interactive_timeout','wait_timeout');+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|28800||WAIT_TIMEOUT|28800|+---------------------+----------------+2rowsinset(0.03 sec)

mysql>setsession WAIT_TIMEOUT=10;

Query OK, 0rows affected (0.00 sec)

-------等待10s后再执行

mysql>selectvariable_name,variable_valuefrominformation_schema.session_variableswherevariable_namein('interactive_timeout','wait_timeout');

ERROR 2013(HY000): Lost connectiontoMySQL server during query

可以看到,等待10s后再执行操作,连接已经断开。

只修改interactive_timeout参数

mysql>selectvariable_name,variable_valuefrominformation_schema.session_variableswherevariable_namein('interactive_timeout','wait_timeout');+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|28800||WAIT_TIMEOUT|28800|+---------------------+----------------+2rowsinset(0.06 sec)

mysql>setsession INTERACTIVE_TIMEOUT=10;

Query OK, 0rows affected (0.00sec)

----------等待10s后执行mysql

>selectvariable_name,variable_valuefrominformation_schema.session_variableswherevariable_namein('interactive_timeout','wait_timeout');+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|10||WAIT_TIMEOUT|28800|+---------------------+----------------+2rowsinset(0.06sec)

Q2:会话变量wait_timeout的继承问题

A2:如果是交互式连接,则继承全局变量interactive_timeout的值,如果是非交互式连接,则继承全局变量wait_timeout的值。

验证:

只修改全局变量interactive_timeout的值

mysql>selectvariable_name,variable_valuefrominformation_schema.global_variableswherevariable_namein('interactive_timeout','wait_timeout');

+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|28800||WAIT_TIMEOUT|28800|+---------------------+----------------+2rowsinset(0.13 sec)

mysql>setglobal INTERACTIVE_TIMEOUT=10;

Query OK, 0rows affected (0.00 sec)

mysql>selectvariable_name,variable_valuefrominformation_schema.global_variableswherevariable_namein('interactive_timeout','wait_timeout');

+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|10||WAIT_TIMEOUT|28800|+---------------------+----------------+2rowsinset(0.00sec)

开启另外一个mysql客户端,查看会话变量的值

mysql>selectvariable_name,variable_valuefrominformation_schema.session_variableswherevariable_namein('interactive_timeout','wait_timeout');

+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|10||WAIT_TIMEOUT|10|+---------------------+----------------+2rowsinset(0.00sec)

发现,WAIT_TIMEOUT的值已经变为10了。

但通过jdbc测试,wait_timeout的值依旧是28800

publicclass Jdbc_test {

    @SuppressWarnings("static-access")

    publicstaticvoidmain(String[] args)throws Exception {

        Connection conn =null;

        Statement stmt =null;

        ResultSet rs =null;

        String url = "jdbc:mysql://192.168.244.10:3306/test";

        String user = "root";

        String password = "123456";

        Class.forName("com.mysql.jdbc.Driver");

        conn = DriverManager.getConnection(url, user, password);

        stmt = conn.createStatement();

        String sql = "select variable_name,variable_value from information_schema.session_variables where variable_name in ('interactive_timeout','wait_timeout')";

        rs = stmt.executeQuery(sql);

        while (rs.next()) {

            System.out

                    .println(rs.getString(1)+":  "+rs.getString(2));

        }    }

}

结果输出如下:

INTERACTIVE_TIMEOUT:  10WAIT_TIMEOUT:  28800

只修改全局变量wait_timeout的值

mysql>selectvariable_name,variable_valuefrominformation_schema.global_variableswherevariable_namein('interactive_timeout','wa

it_timeout');+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|28800||WAIT_TIMEOUT|28800|+---------------------+----------------+2rowsinset(0.17 sec)

mysql>setglobal WAIT_TIMEOUT=20;

Query OK, 0rows affected (0.07 sec)

mysql>selectvariable_name,variable_valuefrominformation_schema.global_variableswherevariable_namein('interactive_timeout','wa

it_timeout');+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|28800||WAIT_TIMEOUT|20|+---------------------+----------------+2rowsinset(0.00sec)

开启另外一个mysql客户端,查看会话变量的值

mysql>selectvariable_name,variable_valuefrominformation_schema.session_variableswherevariable_namein('interactive_timeout','wait_timeout');+---------------------+----------------+|variable_name|variable_value|+---------------------+----------------+|INTERACTIVE_TIMEOUT|28800||WAIT_TIMEOUT|28800|+---------------------+----------------+2rowsinset(0.03sec)

WAIT_TIMEOUT的值依旧是28800.

查看jdbc的结果

publicclass Jdbc_test {

    @SuppressWarnings("static-access")

    publicstaticvoidmain(String[] args)throws Exception {

        Connection conn =null;

        Statement stmt =null;

        ResultSet rs =null;

        String url = "jdbc:mysql://192.168.244.10:3306/test";

        String user = "root";

        String password = "123456";

        Class.forName("com.mysql.jdbc.Driver");

        conn = DriverManager.getConnection(url, user, password);

        stmt = conn.createStatement();

        String sql = "select variable_name,variable_value from information_schema.session_variables where variable_name in ('interactive_timeout','wait_timeout')";

        rs = stmt.executeQuery(sql);

        while (rs.next()) {

            System.out

                    .println(rs.getString(1)+":  "+rs.getString(2));

        }

        Thread.currentThread().sleep(21000);

        sql = "select 1 from dual";

        rs = stmt.executeQuery(sql);

        while (rs.next()) {

            System.out

                    .println(rs.getInt(1));

        }

    }

}

查看jdbc的结果

INTERACTIVE_TIMEOUT:  28800WAIT_TIMEOUT:  20

同时,新增了一段程序,等待20s后,再次执行查询,报如下错误:

Exception in thread "main" com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

Last packet sent to the server was 12 ms ago.

    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)

    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)

    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)

    at java.lang.reflect.Constructor.newInstance(Unknown Source)

    at com.mysql.jdbc.Util.handleNewInstance(Util.java:406)

    at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:1074)

    at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:3009)

    at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:2895)

    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3438)

    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1951)

    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2101)

    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2548)

    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2477)

    at com.mysql.jdbc.StatementImpl.executeQuery(StatementImpl.java:1422)

    at com.victor_01.Jdbc_test.main(Jdbc_test.java:29)

Caused by: java.net.SocketException: Software caused connection abort: recv failed

    at java.net.SocketInputStream.socketRead0(Native Method)

    at java.net.SocketInputStream.socketRead(Unknown Source)

    at java.net.SocketInputStream.read(Unknown Source)

    at java.net.SocketInputStream.read(Unknown Source)

    at com.mysql.jdbc.util.ReadAheadInputStream.fill(ReadAheadInputStream.java:113)

    at com.mysql.jdbc.util.ReadAheadInputStream.readFromUnderlyingStreamIfNecessary(ReadAheadInputStream.java:160)

    at com.mysql.jdbc.util.ReadAheadInputStream.read(ReadAheadInputStream.java:188)

    at com.mysql.jdbc.MysqlIO.readFully(MysqlIO.java:2452)

    at com.mysql.jdbc.MysqlIO.reuseAndReadPacket(MysqlIO.java:2906)

    ... 8 more

总结

1. 控制连接最大空闲时长的wait_timeout参数。

2. 对于非交互式连接,类似于jdbc连接,wait_timeout的值继承自服务器端全局变量wait_timeout。

    对于交互式连接,类似于mysql客户单连接,wait_timeout的值继承自服务器端全局变量interactive_timeout。

3. 判断一个连接的空闲时间,可通过show processlist输出中Sleep状态的时间

mysql> show processlist;+----+------+----------------------+------+---------+------+-------+------------------+|Id|User|Host|db|Command|Time|State|Info|+----+------+----------------------+------+---------+------+-------+------------------+|2|root|localhost|NULL|Query|0|init|show processlist||6|repl|192.168.244.20:44641|NULL|Sleep|1154||NULL|+----+------+----------------------+------+---------+------+-------+------------------+2rowsinset(0.03sec)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,108评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,699评论 1 296
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,812评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,236评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,583评论 3 288
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,739评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,957评论 2 315
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,704评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,447评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,643评论 2 249
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,133评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,486评论 3 256
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,151评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,108评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,889评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,782评论 2 277
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,681评论 2 272

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,296评论 18 399
  • 命运 命运真是残酷 残酷的使我信仰 爱 我爱 不,我不爱 我的爱是无言 笔 小小一支笔 勾勒整个天下 追求 我想 ...
    公子黎阅读 135评论 0 0
  • 开始要日更了,为什么做呢? 1.提高自己的输出,更多的是现在的状态是喜欢说,不喜欢写。再简单一点就是想让出与入达...
    妮妮Gloria阅读 133评论 2 8
  • 即便无奈的现实击碎了梦幻的泡影, 我依旧不能释怀那美妙的一瞬, 有如昙花一现的幻影, 有如纯洁至美的精灵。 在平凡...
    JavaLily阅读 354评论 2 2