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

mysql死锁时间_mysql死锁deadlock相关几个系统变量innodb_lock_wait_timeout

前言随着对于mysql死锁知识的进一步了解,发现与死锁相关的几个系统变量。下面梳理这几个技术概念,便于更进一步掌握mysql死锁的概念。这样在出现一些复

前言

随着对于mysql死锁知识的进一步了解,发现与死锁相关的几个系统变量。下面梳理这几个技术概念,便于更进一步掌握mysql死锁的概念。这样在出现一些复杂的死锁问题时,也有助于更快速解决故障。

innodb_deadlock_detect系统变量

mysql 5.7.15引入此系统变量,可取值有2个,分别为:off与on。

默认值为on,表明开启互锁检测功能。

但是有运维经验的同学或许碰到过,在一些高并发的数据库,如果开启了死锁检测,因为死锁检测进程会去检测是否发现死锁,则会导致数据库性能下降,因为系统必须消耗资源用于定期检测是否发生死锁。

建议在高并发情况下,可以考虑关闭此功能。当然一般情况,保持默认值即可。

innodb_lock_wait_timeout系统变量

innodb_lock_wait_timeout只能用于innodb表的事务(不适用于myisam表,因此它只有表锁,而无行锁功能)。在发生锁等

待时,到达指定的值,则提示锁等待超时,自动回滚报 锁超时 的当前SQL语句(注:不是事务),这样的话,就会导致所属事务的产生数据不一致。所以必须保证在让整个事务回滚,这个由系统变量 innodb_rollback_on_timeout或者命令行选项--innodb-rollback-on-timeout控制。

innodb_lock_wait_timeout单位为秒,默认值为50秒。如果出现锁超时,报错信息见下:

ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

对于高并发的OLTP数据库环境,建议减少innodb_lock_wait_timeout系统变量。你试想一下,如果锁超时时间检查一短,就可以提升并发度;而对于OLAP数据库,可以考虑增加innodb_lock_wait_timeout系统变量,因为OLAP不需要很高的并发度,如果此值过低,锁超时会话就可以等待其它持锁会话完成,而不是马上报错回滚,毕竟每次更新的数据量极大,一回滚半天白作了。

如果启用了innodb_deadlock_detect=on(默认值),则innodb_lock_wait_timeout不会起作用。因为启用前者,一发现死锁,马上回滚某个死锁事务。但如果配置innodb_deadlock_detect=off,则innodb_lock_wait_timeout会起作用,让后者来控制死锁的回滚。

mysql> show variables like '%innodb%lock%timeout%';

+--------------------------+-------+

| Variable_name            | Value |

+--------------------------+-------+

| innodb_lock_wait_timeout | 50    |

+--------------------------+-------+

1 row in set (0.00 sec)

培训课件

a0e1138e9b8f94cd07d2befe9f2f377f.png

a1d88100f7ad6ae96e755f343b4042a5.png

联系方式

6616b10ea6bb74f77c112bc4d31cf954.png

d557a69fff318050fbf92dbf98607bca.png



推荐阅读
  • MySQL数据库锁机制及其应用(数据库锁的概念)
    本文介绍了MySQL数据库锁机制及其应用。数据库锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,数据是一种供许多用户共享的资源,如何保证数据并发访问的一致性和有效性是数据库必须解决的问题。MySQL的锁机制相对简单,不同的存储引擎支持不同的锁机制,主要包括表级锁、行级锁和页面锁。本文详细介绍了MySQL表级锁的锁模式和特点,以及行级锁和页面锁的特点和应用场景。同时还讨论了锁冲突对数据库并发访问性能的影响。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 数据库锁的分类和应用
    本文介绍了数据库锁的分类和应用,包括并发控制中的读-读、写-写、读-写/写-读操作的问题,以及不同的锁类型和粒度分类。同时还介绍了死锁的产生和避免方法,并详细解释了MVCC的原理以及如何解决幻读的问题。最后,给出了一些使用数据库锁的实际场景和建议。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • Oracle Database 10g许可授予信息及高级功能详解
    本文介绍了Oracle Database 10g许可授予信息及其中的高级功能,包括数据库优化数据包、SQL访问指导、SQL优化指导、SQL优化集和重组对象。同时提供了详细说明,指导用户在Oracle Database 10g中如何使用这些功能。 ... [详细]
  • 本文详细介绍了MysqlDump和mysqldump进行全库备份的相关知识,包括备份命令的使用方法、my.cnf配置文件的设置、binlog日志的位置指定、增量恢复的方式以及适用于innodb引擎和myisam引擎的备份方法。对于需要进行数据库备份的用户来说,本文提供了一些有价值的参考内容。 ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了Oracle存储过程的基本语法和写法示例,同时还介绍了已命名的系统异常的产生原因。 ... [详细]
  • 先看一段错误日志:###Errorqueryingdatabase.Cause:com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransie ... [详细]
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
  • 如何利用 Myflash 解析 binlog ?
    本文主要介绍了对Myflash的测试,从准备测试环境到利用Myflash解析binl ... [详细]
  • 上图是InnoDB存储引擎的结构。1、缓冲池InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。因此可以看作是基于磁盘的数据库系统。在数据库系统中,由于CPU速度 ... [详细]
  • 云原生应用最佳开发实践之十二原则(12factor)
    目录简介一、基准代码二、依赖三、配置四、后端配置五、构建、发布、运行六、进程七、端口绑定八、并发九、易处理十、开发与线上环境等价十一、日志十二、进程管理当 ... [详细]
author-avatar
帕格迪奥
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有