连接的超时时间

set global interactive_timeout=120;
set global wait_timeout=120;

该连接指类似应用访问数据库的连接,可以是查询、DML、DDL等

测试一:超时后,DML事务断开,相当于事务提交失败,原数据无变化

mysql> select sysdate();begin;update test set tvalue='' where test_id=5;
+---------------------+
| sysdate() |
+---------------------+
| 2018-09-22 11:08:45 |
+---------------------+
1 row in set (0.00 sec) Query OK, 0 rows affected (0.00 sec) Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select sysdate();commit;
ERROR 2006 (HY000): MySQL server has gone away
No connection. Trying to reconnect...
Connection id: 344
Current database: vodb +---------------------+
| sysdate() |
+---------------------+
| 2018-09-22 11:10:47 |
+---------------------+
1 row in set (0.00 sec) Query OK, 0 rows affected (0.00 sec) mysql> select test_id,tvalue from test;
+---------+-----------------------------------------------------------------------------+
| test_id | tvalue |
+---------+-----------------------------------------------------------------------------+
| 1 | 有张有驰有分寸0 |
| 2 | 适当休息有利于提高工作效率 |
| 3 | 人类对事物的看法达成一致时,可以形成精神层面的共鸣 |
| 4 | 有张有驰有分寸3 |
| 5 | 456 |
+---------+-----------------------------------------------------------------------------+
5 rows in set (0.00 sec)

注意:超时后会出现,下面的信息,后面的连接是客户端自己又重新连接的,事务已经失效了

ERROR 2006 (HY000): MySQL server has gone away

下面是在连接120时间内提交,事务就会成功

mysql> select test_id,tvalue from test;
+---------+-----------------------------------------------------------------------------+
| test_id | tvalue |
+---------+-----------------------------------------------------------------------------+
| 1 | 有张有驰有分寸0 |
| 2 | 适当休息有利于提高工作效率 |
| 3 | 人类对事物的看法达成一致时,可以形成精神层面的共鸣 |
| 4 | 有张有驰有分寸3 |
| 5 | 456 |
+---------+-----------------------------------------------------------------------------+
5 rows in set (0.00 sec) mysql>
mysql>
mysql> select sysdate();begin;update test set tvalue='' where test_id=5;
+---------------------+
| sysdate() |
+---------------------+
| 2018-09-22 11:32:55 |
+---------------------+
1 row in set (0.00 sec) Query OK, 0 rows affected (0.00 sec) Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select sysdate();commit;
+---------------------+
| sysdate() |
+---------------------+
| 2018-09-22 11:34:14 |
+---------------------+
1 row in set (0.00 sec) Query OK, 0 rows affected (0.09 sec) mysql> select test_id,tvalue from test;
+---------+-----------------------------------------------------------------------------+
| test_id | tvalue |
+---------+-----------------------------------------------------------------------------+
| 1 | 有张有驰有分寸0 |
| 2 | 适当休息有利于提高工作效率 |
| 3 | 人类对事物的看法达成一致时,可以形成精神层面的共鸣 |
| 4 | 有张有驰有分寸3 |
| 5 | 123 |
+---------+-----------------------------------------------------------------------------+
5 rows in set (0.00 sec)

参数的设置需要需要下面两个参数一起设置,注意查看是否生效的时候,要使用show global variables like '%timeout';

set global interactive_timeout=120;
set global wait_timeout=120;

测试二:wait_timeout是空闲连接的超时时间,如果一个连接正在query,而不是sleep状态,则超时也不会断开

set global interactive_timeout=60;
set global wait_timeout=60;

set interactive_timeout=60;
set wait_timeout=60;

test表有5万数据,正在不断插入数据,自连接进行笛卡尔集查询,时间远远超过了连接的超时设置60,但连接并没有断开,所以这里的连接指的是空连接;

mysql> select count(aa.tvalue) from test aa,test bb where aa.tid=bb.tid ;
+------------------+
| count(aa.tvalue) |
+------------------+
| 50015 |
+------------------+
1 row in set (2 min 58.55 sec)

DDL锁超时时间

mysql> set global lock_wait_timeout=5;
Query OK, 0 rows affected (0.11 sec) mysql>
mysql>
mysql> show global variables like '%lock_wait%';
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| innodb_lock_wait_timeout | 50 |
| lock_wait_timeout | 5 |
+--------------------------+-------+
2 rows in set (0.51 sec)

修改DDL超时时间为5秒,结果很悲剧,5秒时该DDL未执行完,mysql实例直接关闭了,这个参数的默认时间31536000秒(365天),最好还是不要改动了

mysql> alter table test drop column beizhu;
ERROR 2013 (HY000): Lost connection to MySQL server during query

DML事务锁超时时间

set global innodb_lock_wait_timeout=30;

set innodb_lock_wait_timeout=30;

一个innodb事务等待一个row lock的秒数,超时这个秒数,则该innodb事务就不再等了,直接回退了。此处设置为30秒,实验如下

会话一,事务持续超过了30秒,在这中间执行了会话二

mysql> select sysdate();begin;update test set tvalue='一些小的痛苦可以引人思考,让人成长;但长时间深陷痛苦之中,则会伤害身心' where test_id=4;
+---------------------+
| sysdate() |
+---------------------+
| 2018-09-22 22:13:25 |
+---------------------+
1 row in set (0.00 sec) Query OK, 0 rows affected (0.00 sec) Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select sysdate();commit;
+---------------------+
| sysdate() |
+---------------------+
| 2018-09-22 22:14:03 |
+---------------------+
1 row in set (0.00 sec) Query OK, 0 rows affected (0.01 sec)

会话二,在会话一执行的中间执行,在第31秒时,出现了 lock wait timeout,然后原数据并未变化,也就是说事务回退了

mysql> select sysdate();update test set tvalue='小痛助长,大痛伤身' where test_id=4;
+---------------------+
| sysdate() |
+---------------------+
| 2018-09-22 22:13:30 |
+---------------------+
1 row in set (0.00 sec) ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
mysql> select tid,tvalue from test where test_id<6;
+------+-----------------------------------------------------------------------------------------------------------+
| tid | tvalue |
+------+-----------------------------------------------------------------------------------------------------------+
| 0 | 有张有驰有分寸0 |
| 1 | 适当休息有利于提高工作效率 |
| 2 | 人类对事物的看法达成一致时,可以形成精神层面的共鸣 |
| 3 | 一些小的痛苦可以引人思考,让人成长;但长时间深陷痛苦之中,则会伤害身心 |
| 4 | 123 |
+------+-----------------------------------------------------------------------------------------------------------+
5 rows in set (0.00 sec)

注意,这是说一个事务等待一个row lock的最大时间,但是事务本身需要很久的时间是没有问题的,是可以执行成功的;同时也说明,一个长事务有让其他的事务失效回退的可能。本例是Mysql7.2.22,RR事务隔离级别。

test表已有120万数据量(还在不断插入数据中),让它自己跟自己笛卡尔一下就能产生个长事务,test_id是索引字段,tid上无索引,这是在全表所有row的tid列上加锁

mysql> update test aa,test bb set aa.tid=bb.test_id where bb.tid = aa.tid;

下面的这个事务在等待30秒后,就自动回退了,这就是长事务阻断了其他事务的情况

mysql> update test aa set aa.tid = 7 where aa.tid=8;
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

my18_mysql中的几个超时时间的更多相关文章

  1. golang中mysql建立连接超时时间timeout 测试

    本文测试连接mysql的超时时间. 这里的"连接"是建立连接的意思. 连接mysql的超时时间是通过参数timeout设置的. 1.建立连接超时测试 下面例子中,设置连接超时时间为 ...

  2. config文件中可以配置查询超时时间

    web.config配置数据库连接 第一种:获取连接字符串 首先要定义命名空间 system.configuration 1.  string connstr= string constr = Con ...

  3. Python中为feedparser设置超时时间教程

    python有一个用于解析feed的模块:feedparser,feedparser解析各种feed是非常方便的,唯一比较恼火的是遇到一些badurl,经常会导致堵塞,因此需要为feedparser设 ...

  4. 修改phpMyAdmin中的默认1440超时时间

    步骤一:修改PHP配置中session的过期时间. session.gc_maxlifetime = 1440 //改为 session.gc_maxlifetime = 14400 步骤二:修改ph ...

  5. httpClient中的三种超时设置小结

    httpClient中的三种超时设置小结   本文章给大家介绍一下关于Java中httpClient中的三种超时设置小结,希望此教程能给各位朋友带来帮助. ConnectTimeoutExceptio ...

  6. WebLogic如何设置session超时时间

    1.web.xml  设置WEB应用程序描述符web.xml里的<session-timeout>元素.这个值以分钟为单位,并覆盖weblogic.xml中的TimeoutSecs属性   ...

  7. Mybatis设置超时时间

    Mybatis设置超时时间 mybatis如果不指定,默认超时时间是不做限制的,默认值为0.mybatis sql配置超时时间有两种方法: 1.全局配置 在mybatis配置文件的settings节点 ...

  8. 使用timeout-decorator为python函数任务设置超时时间

    需求背景 在python代码的实现中,假如我们有一个需要执行时间跨度非常大的for循环,如果在中间的某处我们需要定时停止这个函数,而不停止整个程序.那么初步的就可以想到两种方案:第一种方案是我们先预估 ...

  9. 连接字符串中Min Pool Size的理解是错误,超时时间已到,但是尚未从池中获取连接。出现这种情况可能是因为所有池连接均在使用,并且达到了最大池大小。

    Min Pool Size的理解是错误的 假设我们在一个ASP.NET应用程序的连接字符串中将Min Pool Size设置为30: <add name="cnblogs" ...

随机推荐

  1. String/StringBuilder 类 用对象数组实现登录注册功能

    一.需求说明:实现用户注册.登陆功能: 程序中使用一个长度为3的对象数组,存储用户的登录名和密码: 例如如下格式: 登录名    密码      生日           爱好 zhangsan 11 ...

  2. Struts第三天

    OgnlValueStack贯穿整个 Action 的生命周期. 它是ContextMap中的一部分,里面的结构是一个List,是我们可以快速访问数据一个容器.它的封装是由struts2框架完成的. ...

  3. RTX这种东西究竟有什么价值?

    我在第一家公司工作的时候,同事沟通用的就是RTX,第一感觉就是这么简单的软件也能卖钱? 这种东西有啥价值啊?不就是个没广告蓝色UI的qq吗? 还是那句话,当你已经习惯了一个东西之后,你不会感觉到他的价 ...

  4. p2197 nim游戏

    传送门 分析 我们知道最后取完的情况就是所有的a[i]异或和为0 所以只要开始的异或和不为0则先手一定可以将它转化为0 否则不行 所以如果异或和非0则先手胜 代码 #include<bits/s ...

  5. Javascript parseInt()和parseFloat()的用法

    parseInt()方法首先查看位置0处的 字符,判断它是否是个有效数字:如果不是,该方法将返回NaN,不再继续执行其他操作.但如果该字符是有效数字,该方法将查看位置1处的字符,进行同样的 测试.这一 ...

  6. MSSQL数据库设计心得

    统一库名命名规则. 格式:公司简称_库名 如:Supesoft_Member  会员库 建库时,最好将初始大小设置为你认为可允许的最大容量.避免因为库太小,而出现系统自增加.在系统运行中,自动增加空间 ...

  7. 跑实验配环境(tensorflow)

    最近在学习用CNN(卷积神经网络)做图像质量评价,选择的论文是CVPR2014-Convolutional neural networks for no-reference image quality ...

  8. Timer的schedule和scheduleAtFixedRate方法的区别解析(转)

    在java中,Timer类主要用于定时性.周期性任务 的触发,这个类中有两个方法比较难理解,那就是schedule和scheduleAtFixedRate方法,在这里就用实例分析一下 (1)sched ...

  9. winfrom浏览器控件

    (1)webbrowser 在ie的基础上开发出来的,一般情况下很好用,特殊情况下没法用,一堆坑,h5支持效果不好 使用:直接拖控件就好了 (2)WebKit .NET http://webkitdo ...

  10. MongoDB 分片2

    mongodb 在windows下面进行分片 mongodb 更新很快,在做分片的时候,查找了不少文章,但是很多已经过时了.现在把我搭建的过程及命令分享给大家.我用的是最新版本windows版3.4. ...