热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:my18_mysql中的几个超时时间

本文由编程笔记#小编为大家整理,主要介绍了my18_mysql中的几个超时时间相关的知识,希望对你有一定的参考价值。连接的超时时间
本文由编程笔记#小编为大家整理,主要介绍了my18_mysql中的几个超时时间相关的知识,希望对你有一定的参考价值。


连接的超时时间

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

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

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


mysql> select sysdate();begin;update test set tvalue=123 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=123 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

 


推荐阅读
  • 目录一、salt-job管理#job存放数据目录#缓存时间设置#Others二、returns模块配置job数据入库#配置returns返回值信息#mysql安全设置#创建模块相关 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 本文介绍 SQL Server 的基本概念和操作,涵盖系统数据库、常用数据类型、表的创建及增删改查等基础操作。通过实例帮助读者快速上手 SQL Server 数据库管理。 ... [详细]
  • 本文深入探讨了SQL数据库中常见的面试问题,包括如何获取自增字段的当前值、防止SQL注入的方法、游标的作用与使用、索引的形式及其优缺点,以及事务和存储过程的概念。通过详细的解答和示例,帮助读者更好地理解和应对这些技术问题。 ... [详细]
  • 本文介绍如何使用MFC和ADO技术调用SQL Server中的存储过程,以查询指定小区在特定时间段内的通话统计数据。通过用户界面选择小区ID、开始时间和结束时间,系统将计算并展示小时级的通话量、拥塞率及半速率通话比例。 ... [详细]
  • 1.执行sqlsever存储过程,消息:SQLServer阻止了对组件“AdHocDistributedQueries”的STATEMENT“OpenRowsetOpenDatas ... [详细]
  • 本文详细介绍了一种通过MySQL弱口令漏洞在Windows操作系统上获取SYSTEM权限的方法。该方法涉及使用自定义UDF DLL文件来执行任意命令,从而实现对远程服务器的完全控制。 ... [详细]
  • 阿里云ecs怎么配置php环境,阿里云ecs配置选择 ... [详细]
  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
  • 本文详细介绍了如何在 MySQL 中授予和撤销用户权限。包括创建用户、赋予不同级别的权限(如表级、数据库级、服务器级)、使权限生效、查看用户权限以及撤销权限的方法。此外,还提供了常见错误及其解决方法。 ... [详细]
  • 本文介绍了数据库体系的基础知识,涵盖关系型数据库(如MySQL)和非关系型数据库(如MongoDB)的基本操作及高级功能。通过三个阶段的学习路径——基础、优化和部署,帮助读者全面掌握数据库的使用和管理。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • 深入理解Lucene搜索机制
    本文旨在帮助读者全面掌握Lucene搜索的编写步骤、核心API及其应用。通过详细解析Lucene的基本查询和查询解析器的使用方法,结合架构图和代码示例,带领读者深入了解Lucene搜索的工作流程。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
  • 本文详细探讨了JavaScript中的作用域链和闭包机制,解释了它们的工作原理及其在实际编程中的应用。通过具体的代码示例,帮助读者更好地理解和掌握这些概念。 ... [详细]
author-avatar
phpxiaoxuesheng
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有