MySQL 全局锁、表锁和行锁

这篇具有很好参考价值的文章主要介绍了MySQL 全局锁、表锁和行锁。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、全局锁

全局锁,是指对整个MySQL数据库加锁,对应的命令是flush tables with read lock;(以下简称FTWRL)

当你需要让整个库处于只读模式的时候,可以使用这个语法,它的应用场景,一般是在全库逻辑备份的时候。我们知道MySQL自带的mysqldump逻辑备份工具可以使用--single-transaction参数来进行备份,因为Innodb存储引擎支持事务和MVCC的原理,所以该备份方法没有问题。但是,在你使用MyISAM等存储引擎时,该语句可以保证在备份期间的数据一致性。而

--single-transaction方法只适用于所有的表使用事务引擎的库;

2、表级锁

MySQL里面表级别的锁有两种,一种是表锁,一种是元数据锁(MDL)

表锁的加锁方式为lock tables xxx read,解锁方式是unlock tables xxx,需要注意的是:

lock tables语法除了会限制别的线程的读写外,也限定了本线程接下来的操作对象。举个例子, 如果在某个线程A中执行lock tables t1 read, t2 write; 这个语句,则其他线程写t1、读写t2的语句都会被阻塞。当前线程也不能对表t1做写的操作

MDL元数据锁是指在对一个表做增删改查的时候,MySQL会对该表加MDL读锁,防止另外一个线程对该表做变更操作,当对一个表做表结构变更的时候,会对该表加MDL写锁。MDL锁不需要显式使用,在访问一个表的时候会被自动加上

MDL锁可能会造成MySQL宕掉!!!举例如下:

当我们开启多个事务的时候,假设事务的内容都是一个begin+简单的select语句(加MDL读锁),当其中一个事务没有及时提交,此时如果有一个alter table的操作(导致MDL读锁升级为MDL写锁),会导致后续的select语句,都被阻塞,即使这个表的记录数很少,在事务不及时提交的情况下,也会导致整个库不可读。如果此时应用方面有重连机制,则会导致连接数被快速打满,这往往是灾难性的。此场景中,即使使用pt工具进行表结构变更,也无法解决问题。

还需要注意,如果事务中没有begin的话,这样select执行完成以后,MDL就自动释放了,则不会造成MDL锁等待。

3、行锁

行锁里面比较重要的一个概念:两阶段锁,它是指:

在InnoDB事务中,行锁是在需要的时候才加上的,但并不是不需要了就立刻释放,而是要等到事务结束时(commit动作完成之后)才释放。

从这个两阶段锁机制中我们不难发现一个好的习惯:

如果你的事务中需要锁多个行,要把最可能造成锁冲突、最可能影响并发度的锁尽量往后放

行锁的产生,可以大大降低死锁的概率(是降低,不是杜绝),但是这种热点行的频繁更新,往往会导致MySQL的性能问题(因为死锁检测会消耗大量的CPU资源)。如何解决热点行的频繁更新带来的性能问题?

1、关闭死锁检测参数innodb_deadlock_detect,这种操作,往往不是最优的,因为可能出现大量因为死锁带来的超时问题。

2、控制并发,核心思路就是相同行的更新,在进入引擎之前进入队列排队。

最后,死锁的两个关键参数:

innodb_deadlock_detect:死锁检测参数,默认为on,发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务得以继续执行

innodb_lock_wait_timeout:死锁等待的超时时间,默认为50s,意味着如果不开启死锁检测,则在发生死锁之后,会等待50s,直到超时。

----------------------------

思考题:

备份一般都会在备库上执行,你在用–single-transaction方法做逻辑备份的过程中,如果主库上的一个小表做了一个DDL,比如给一个表上加了一列。这时候,从备库上会看到什么现象呢?

参考答案:

本质上,MySQLdump+transaction参数进行备份的过程中,我们可以认为它做了如下的动作:

T0:begin;

T1:savepoint sp;

T2: show create t1;

T3:select * from t1;(执行一段时间)

T4:rollback to sp;

T1时刻mysqldump设置一个保存点,然后拿到t1表的表结构(T2)和表数据(T3),最后,再回到保存点sp(T4),整个过程中,如果:

在T2时间之前,在表上增加了一列,从库上没有影响。

在T2和T3之间,在表上增加了一列,则报错 Table definition has changed, please retry transaction

MySQL备份中止

在T3期间到达,则因为此时正在备份,mysqldump占着t1的MDL读锁,binlog被阻塞,现象:主从延迟,直到T4执行完成

在T3和T4之间到达,则没有影响,因为mysqldump已经释放了MDL读锁文章来源地址https://www.toymoban.com/news/detail-481638.html

到了这里,关于MySQL 全局锁、表锁和行锁的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【MySQL】说透锁机制(三)行锁升表锁如何避免? 锁表了如何排查?

    在上文我们曾小小的提到过,在 索引失效 的情况下,MySQL会把 所有聚集索引记录和间隙 都锁上,我们称之为 锁表 ,或叫 行锁升表锁 . 那么对于 行锁升表锁 ,有的同学误以为 行锁 升级变成了 表锁 ,但实际上 锁的类型并没有发生变化 ✍️, 还是行锁! 只是表的所有聚集

    2024年04月10日
    浏览(41)
  • 数据库update语句到底是行锁还是表锁?

    先说结论: 无索引的情况下,如果不走主键,那么update为表锁;有索引的情况下,走索引或者走主键(效果一样),那么update变为行锁。 大致把问题分为两种情况:有索引或者没有索引 先建一个没有索引的表,模拟一些数据,并且把事务自动提交关掉。 我们先在第一个查询

    2023年04月09日
    浏览(52)
  • MySQL锁(读锁、共享锁、写锁、S锁、排它锁、独占锁、X锁、表锁、意向锁、自增锁、MDL锁、RL锁、GL锁、NKL锁、插入意向锁、间隙锁、页锁、悲观锁、乐观锁、隐式锁、显示锁、全局锁、死锁)

    本文说明的是MySQL锁,和操作系统或者编程语言的锁无关。 作用:在并发情况下让数据正确的读写。 优点:并发情况下对数据读写可控,防止出错。 缺点:降低性能、增加难度。 数据操作类型划分 读锁(共享锁、S锁) 写锁(排它锁、独占锁、X锁) 粒度划分 表级锁 S锁、

    2024年03月10日
    浏览(49)
  • MySQL行锁浅析

    MySQL是非常流行的关系型数据库,许多系统都使用它来存储和管理数据。在高并发环境下,为了保证数据的一致性和可靠性,数据库需要实现并发控制,其中包括锁机制。MySQL提供了两种锁类型,一种是表级锁,另一种是行级锁。本文将深入探讨MySQL中的行级锁,包括行锁概念

    2024年02月07日
    浏览(41)
  • VS2022 全局查找 整个解决方案失效

    问题现象: 在VS2022中 Ctrl+F 整个解决方案中无法查找到,但是在当前文档可以查找到。VS2015 VS2017 VS2019均可以全局查找到。 解决方案: 网上查询过程中尝试了3种方案: 重启 VS2022、重启Windows ; 删除解决方案所在文件目录的 .vs 文件夹; 删除 \\\"【VS2022安装目录】C

    2024年02月11日
    浏览(56)
  • Mysql行锁失效情况分析

    数据库版本:使用Mysql8.0.32作为测试版本,InnoDB引擎。 本文阐述Mysql行锁失效升级为表的场景。 使用远程终端打开两个数据库服务器(Linux)窗口,使用如下命令登录: 回车,输入数据库密码. 测试数据库为: test 关闭自动提交 测试数据表为: 其中id是主键。 插入两条id分别为

    2024年02月02日
    浏览(44)
  • Mysql InnoDB行锁深入理解

    Record Lock 称为记录锁,锁住的是一条记录。而且记录锁是有 S 锁和 X 锁之分的: 当一个事务对一条记录加了 S 型记录锁后,其他事务也可以继续对该记录加 S 型记录锁(S 型与 S 锁兼容),但是不可以对该记录加 X 型记录锁(S 型与 X 锁不兼容); 当一个事务对一条记录加了

    2024年01月22日
    浏览(53)
  • 【MySQL】表列数和行大小限制详解

    目录 限制维度 列数量限制 表的最大行大小 单个列的存储要求 存储引擎的附加限制 功能键部分 行容量限制 MySQL表的内部实现 InnoDB表的最大行大小 超出InnoDB最大行大小的处理 不同存储格式的影响 限制示例 行大小限制示例 InnoDB下 MyISAM下 InnoDB变长情况示例 MyISAM变长情况示例

    2024年01月24日
    浏览(32)
  • MySQL中锁的简介——表级锁-表锁

    2024年02月15日
    浏览(35)
  • C/C++编译器全局优化技术:全局优化是针对整个程序进行的优化,包括函数之间的优化

    编程语言的设计和实现与人类心理学有着密切的联系。C++编译器全局优化技术在这个领域中是一个重要的例子。在这篇博客中,我们将从心理学的角度来探讨C++编译器全局优化技术的原理和实践。 人类大脑的神经网络在处理信息时,会自动进行优化以提高效率。我们的思维和

    2023年04月26日
    浏览(73)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包