MySQL-锁

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL-锁

MySQL-锁

锁分类

MySQL中锁按照粒度分,分为以下三类

  • 全局锁:锁定数据库中的所有表
  • 表级锁:每次操作锁住整张表
  • 行级锁:每次操作锁住对应的行数据

全局锁

  • 全局锁就是对整个数据库实例加锁,加锁后整个实例就处于只读状态,后续的DML的写语句,DDL语句,已经更新操作的事务提交语句都将被阻塞
语法
  • 加全局锁

    FLUSH TABLES WITH READ LOCK;
  • 释放锁

    UNLOCK TABLES;
数据备份
  • 通常,我们为了保障多张表的数据一致性,在数据备份时我们会打开全局锁后进行数据备份,等待数据备份完成后对锁进行释放
  • MySQL为我们提供了一个数据备份工具mysqldump,我们可以通过以下命令进行数据备份

    mysqldump -uroot –proot dbname > xxx.sql
  • 但是数据库开启全局锁时,会导致整体的业务摆停,所以为了解决这个问题,在InnoDB引擎中,我们可以在备份时加上参数 --single-transaction 参数来完成不加锁的一致性数据备份

    mysqldump --single-transaction -uroot –proot dbname > xxx.sql
特点

数据库中加全局锁,是一个比较重的操作,存在以下问题

  • 如果在主库上备份,那么在备份期间都不能执行更新,业务基本上就得停摆
  • 如果在从库上备份,那么在备份期间从库不能执行主库同步过来的二进制日志(binlog),会导致主从延迟

表级锁

介绍
  • 表级锁,每次操作锁住整张表。锁定粒度大,发生锁冲突的概率最高,并发度最低。应用在MyISAM、InnoDB、BDB等存储引擎中
分类

对于表级锁分为以下三类

  • 表锁
  • 元数据锁(Meta Data Lock)
  • 意向锁
表锁

对于表锁,分为两类:

  • 表共享读锁(read lock)
  • 表独享写锁 (write lock)

语法

  • 加锁

    LOCK TABLES 表名 ... READ/WRITE
  • 释放锁

    UNLOCK TABLES / 客户端释放连接

特点

  • 当线程A对表加上读锁时,线程A可以读但是不可以对表进行写操作,不会影响线程B的读但是会阻塞线程B的写,等待线程A释放读锁
  • 当线程A对表加上写锁时,线程A可以进行读操作,也可以进行写操作,线程B既不能读也不能写
元数据锁

介绍

  • 元数据锁,简称为MDL,作用主要是维护表的元数据的一致性,在表存在未提交的事务时防止表的结构被修改,MDL锁的加锁过程由系统自动控制,无需显示加锁
  • 当对一张表执行增删改查操作时会自动添加DML读共享锁,当对表结构进行变更操作的时候,加DML排他锁

常见SQL操作所加的元数据锁

bdbb4cd9b42c4abb900b876ee9480747.png

  • 当执行SELECT、INSERT、UPDATE、DELETE等语句时,添加的是元数据共享锁(SHARED_READ /SHARED_WRITE),之间是兼容的
  • 当执行SELECT语句时,添加的是元数据共享锁(SHARED_READ),会阻塞元数据排他锁(EXCLUSIVE),之间是互斥的

查看数据库中的元数据锁情况

select object_type,object_schema,object_name,lock_type,lock_duration from performance_schema.metadata_locks ;
意向锁
  • 为了避免DML在执行时,加的行锁与表锁的冲突,在InnoDB中引入了意向锁,使得表锁不用检查每行数据是否加锁,使用意向锁来减少表锁的检查
  • 如何理解意向锁:当行锁存在时对表添加表锁时需要对表进行扫描,确定行锁和表锁不冲突时才可以添加表锁,效率低下,所以在INNODB引擎中引出了表意向锁,它锁住的是整张表,当需要添加表锁时只需要确认表锁和表意向锁不冲突就可以快速添加表锁了,不需要再对表进行扫描

分类

  • 意向共享锁(IS): 由语句select ... lock in share mode添加,与表锁共享锁(read)兼容,与表锁排他锁(write)互斥
  • 意向排他锁(IX): 由insert、update、delete、select...for update添加,与表锁共享锁(read)及排他锁(write)都互斥,意向锁之间不会互斥
  • 一旦事务提交了,意向共享锁、意向排他锁,都会自动释放

查看意向锁和行锁加锁情况

select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;

兼容情况

  • 意向共享锁与表读锁是兼容的,与表写锁互斥
  • 意向排他锁与表读锁和表写锁都是互斥的

行级锁

介绍
  • 行级锁,每次操作锁住对应的行数据。锁定粒度最小,发生锁冲突的概率最低,并发度最高。应用在InnoDB存储引擎中
  • 注意:InnoDB的数据是基于索引组织的,行锁是通过对索引上的索引项加锁来实现的,而不是对记录加的锁
分类
  • 行锁(行数据锁 Record Lock):锁定单个行记录的锁,防止其他事务对此行进行update和delete。在RC、RR隔离级别下都支持
  • 间隙锁(Gap Lock):锁定索引记录间隙(不含该记录),确保索引记录间隙不变,防止其他事务在这个间隙进行insert,产生幻读。在RR隔离级别下都支持
  • 临键锁(Next-Key Lock):行锁和间隙锁组合,同时锁住数据,并锁住数据前面的间隙Gap。在RR隔离级别下支持

e54cc0a5f5d04b33bd6f93ffdabe8b7a.png

行数据锁

分类:InnoDB实现了以下两种类型的行锁

  • 共享锁(S):允许一个事务去读一行,阻止其他事务对该行进行写操作
  • 排他锁(X):允许获取排他锁的事务更新数据,阻止其他事务对该行进行读和写操作

兼容情况:

  • 行共享锁兼容行共享锁,不兼容行排他锁(不允许写操作)
  • 行排他锁不兼容行共享锁,也不兼容行排他锁

SQL执行时加行锁情况:
5d251c95b50345b08d3c27db3dcae8e7.png

  • 默认情况下,InnoDB在 REPEATABLE READ事务隔离级别运行,InnoDB使用 next-key(临键) 锁进行搜索和索引扫描,以防止幻读
  • 针对唯一索引进行检索时,对已存在的记录进行等值匹配时,将会自动优化为行锁
  • InnoDB的行锁是针对于索引加的锁,不通过索引条件检索数据,那么InnoDB将对表中的所有记录加锁,此时就会升级为表锁
间隙锁&临键锁
  • 索引上的等值查询(唯一索引),给不存在的记录加锁时, 优化为间隙锁

    SELECT ... WHERE ID=XXX LOCK IN SHARE MODE; -- ID不存在
  • 索引上的等值查询(非唯一普通索引),向右遍历时最后一个值不满足查询需求时,next-key lock(临键锁)退化为间隙锁
  • 索引上的范围查询(唯一索引),会访问到不满足条件的第一个值为止

7b77ed3457274cfab37d6aa67ebbd202.png

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
SQL 关系型数据库 MySQL
MySQL 锁
MySQL里常见的几种锁
57 3
|
2月前
|
存储 关系型数据库 MySQL
优化 MySQL 的锁机制以提高并发性能
【10月更文挑战第16天】优化 MySQL 锁机制需要综合考虑多个因素,根据具体的应用场景和需求进行针对性的调整。通过不断地优化和改进,可以提高数据库的并发性能,提升系统的整体效率。
122 1
|
2月前
|
关系型数据库 MySQL Java
MySQL数据锁:Record Lock,Gap Lock 和 Next-Key Lock
本文基于 MySQL 8.0.30 版本及 InnoDB 引擎,深入解析三种行锁机制:记录锁(Record Lock)、间隙锁(Gap Lock)和临键锁(Next-key Lock)。记录锁锁定索引记录,确保事务唯一修改;间隙锁锁定索引间的间隙,防止新记录插入;临键锁结合两者,锁定范围并记录自身,有效避免幻读现象。通过具体示例展示了不同锁的作用机制及其在并发控制中的应用。
245 2
|
2月前
|
存储 关系型数据库 MySQL
MySQL数据库锁:共享锁和独占锁
本文详细介绍了`InnoDB`存储引擎中的两种行级别锁:共享锁(S锁)与排他锁(X锁)。通过具体示例展示了这两种锁的工作机制及其在`InnoDB`与`MyISAM`引擎中的表现差异。文章还提供了锁的兼容性矩阵,帮助读者更好地理解锁之间的互斥关系。最后总结了两种锁的特点及适用场景。适合希望深入了解`MySQL`并发控制机制的读者阅读。
94 1
|
3月前
|
监控 关系型数据库 MySQL
MySQL锁机制与解决死锁问题
MySQL锁机制与解决死锁问题
347 5
|
2月前
|
存储 关系型数据库 MySQL
MySQL锁,锁的到底是什么?
【10月更文挑战第16天】MySQL 锁锁定的是与数据和资源相关的对象,其目的是为了保证数据的一致性、避免冲突,并在并发环境下合理协调事务或操作的执行。理解锁的对象和意义对于优化数据库性能、处理并发问题至关重要。
85 0
|
2月前
|
关系型数据库 MySQL 数据库
mysql锁详解
通过理解并合理运用MySQL中的锁机制,开发者可以有效管理数据库并发访问,平衡性能与数据一致性需求。更多关于MySQL锁的深入探讨和最佳实践,请参考专业的数据库管理资源[[深入MySQL锁机制详解
61 0
|
3月前
|
关系型数据库 MySQL 数据库
Mysql的锁
本文介绍了MySQL中表级锁和行级锁的区别,其中MyISAM仅支持表级锁,而InnoDB支持表级锁和行级锁,默认为行级锁。表级锁锁定整个表,实现简单,资源消耗少,但并发度低;行级锁仅锁定相关记录,减少冲突,提高并发度,但加锁开销大。此外,还介绍了共享锁和排他锁的概念及意向锁的作用。
|
3月前
|
存储 SQL 关系型数据库
MySQL 的锁机制,那么多的锁,该怎么区分?
MySQL 的锁机制,那么多的锁,该怎么区分?
51 0
|
4月前
|
监控 关系型数据库 MySQL
在Linux中,mysql的innodb如何定位锁问题?
在Linux中,mysql的innodb如何定位锁问题?