【MySQL-25】万字总结<锁>——(全局锁&行级锁&表级锁)【共享锁,排他锁】【间隙锁,临键锁】【表锁,元数据锁,意向锁】

news2024/9/25 23:23:35

前言

大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎! 本章主要内容面向接触过C++的老铁
主要内容含:
在这里插入图片描述

欢迎订阅 YY滴C++专栏!更多干货持续更新!以下是传送门!

  • YY的《C++》专栏
  • YY的《C++11》专栏
  • YY的《Linux》专栏
  • YY的《数据结构》专栏
  • YY的《C语言基础》专栏
  • YY的《单片机》专栏
  • YY的《STM32》专栏
  • YY的《数据库》专栏

目录

  • ※锁的总结(前瞻)
  • 一.锁的概述&分类
  • 二.全局锁
    • 1.全局锁的基本概念&画图演示
  • 三.行级锁
    • 行级锁的基本概念&分类(行锁 = 临键锁-见隙锁)
    • 【1】【行锁】(共享锁,排他锁)
      • 1.共享锁,排他锁机制介绍
      • 2.不同SQL下,行锁的情况
      • 3.演示行锁
        • 【1】情况1
        • 【2】情况2
    • 【2】【临键锁S】【间隙锁】演示
      • ※【临键锁S】【间隙锁】特性演示目录
      • 1.演示:索引上的等值查询 (唯一索引,例如主键索引)
      • 2.演示:索引上的范围查询(唯一索引)
      • 3.演示:索引上的等值查询(普通索引)——临键锁退化为间隙锁
  • 四.表级锁
    • 表级锁的基本概念&分类【表锁,元数据锁,意向锁】
    • 【1】表锁
    • 【2】元数据锁:MDL
    • 【3】意向锁
      • 1.意向锁的由来
      • 2.意向锁的相关语法(意向共享锁&意向排他锁)(包含语法和演示)

※锁的总结(前瞻)

在这里插入图片描述

一.锁的概述&分类

在这里插入图片描述
在这里插入图片描述

二.全局锁

1.全局锁的基本概念&画图演示

  1. 场景: 备份过程中,其他业务干涉,导致数据不一致
  2. 全局锁的目的: 保护数据一致性
  • 全局锁就是对整个数据库实例加锁,加锁后整个实例就处于 只读状态,后续的DML的写语句,DDL语句, 已经更新操作的事务提交语句都将被阻塞
  • 其典型的使用场景是做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性

在这里插入图片描述

  • 逻辑备份前加上 全局锁
  • 逻辑备份后,解锁
    在这里插入图片描述

三.行级锁

行级锁的基本概念&分类(行锁 = 临键锁-见隙锁)

  • 行级锁,每次操作锁住对应的行数据。锁定粒度最小, 发生锁冲突的概率最低 ,并发度最高应用在Inn0DB存储引擎中。
  • InnoDB的数据是 基于索引组织的 ,行锁是通过对索引上的索引项加锁来实现的, 而不是对记录加的锁

对于行级锁,主要分为以下三类:

  1. 行锁(Record Lock) :锁定单个行记录的锁,防止其他事务对此行进行update和delete。在RC、RR隔离级别下都支持。
    在这里插入图片描述
  • 表达:行锁=临键锁-见隙锁
    在这里插入图片描述
  1. 见隙锁(Gap Lock) :锁定索引记录间隙(不含该记录) 确保索引记录间随不变,防止其他事务在这个间隙进行insert,产生幻读。在RR隔离级别下都支持。
    在这里插入图片描述
  • 表达:GAP
    在这里插入图片描述
  1. 临键锁(Next-KeyLock) 行锁和 它之前的 间隙锁组合 ,同时锁住数据,并锁住数据前面的间隙Gap。在RR隔离级别下支持。
    在这里插入图片描述
  • 表达:S
    在这里插入图片描述

【1】【行锁】(共享锁,排他锁)

1.共享锁,排他锁机制介绍

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

  1. 共享锁(S): 允许一个事务去读一行,阻止其他事务获得相同数据集的排它锁。 (共享锁之间是兼容的 ,共享锁与排他锁互斥)
  2. 排他锁(X): 允许获取排他锁的事务更新数据,阻止其他事务获得相同数据集的共享锁和排他锁。 (一个数据有了排他锁,就与其他共享锁和排他锁互斥)

在这里插入图片描述

2.不同SQL下,行锁的情况

  • 分成两种,一种是增删改;另一种是查询
    在这里插入图片描述

3.演示行锁

默认情况下,InnODB在 REPEATABLE READ事务隔离级别运行,InnoDB使用 临键锁 进行搜索和索引扫描,以防止幻读。(本次演示)

  1. 针对 唯一索引 进行检索时,对已存在的记录进行等值匹配时,将会 自动优化为行锁

  2. 不通过索引条件检索数据(InnoDB的行锁是针对于索引加的锁),那么InnoDB将对表中的所有记录加锁,此时 就会升级为表锁

可以通过以下SOL,查看意向锁及行锁的加锁情况:

select object schema,object name,index name,lock type,lock mode,lock data from performance schema.data locks;
【1】情况1

演示:

  • 我们查看一张表,发现表的id是 主键索引

在这里插入图片描述

  • 我们加入共享锁

在这里插入图片描述

  • 我们查看行锁的加锁情况: 注:TABLE 为表锁 RECORD为行锁
  • 查看查看意向锁及行锁的加锁情况:
select object schema,object name,index name,lock type,lock mode,lock data from performance schema.data locks;
  • 发现有共享锁S,且无间隙锁 REC_NOT_GAP

在这里插入图片描述

  • 我们在另一客户端再加上共享锁,依旧能执行;因为 (共享锁之间是兼容的 ,共享锁与排他锁互斥)

在这里插入图片描述

【2】情况2

不通过索引条件检索数据(InnoDB的行锁是针对于索引加的锁),那么InnoDB将对表中的所有记录加锁,此时 就会升级为表锁
演示:

  • 有这么一张表,为主键索引
    在这里插入图片描述
  • 我们针对非索引条件检索数据name,进行更新操作
  • 此时行锁就会升级成表锁
    在这里插入图片描述
  • 此时我们再开一个终端,对id=3的数据行进行修改,发现进入阻塞状态
    在这里插入图片描述

【2】【临键锁S】【间隙锁】演示

※【临键锁S】【间隙锁】特性演示目录

下面进行演示:

默认情况下,InnODB在 REPEATABLE READ事务隔离级别运行,InnoDB使用 next-key锁进行搜索和索引扫描,以防止幻读。

  1. 索引上的等值查询 (唯一索引,例如主键索引) ,给 不存在的记录 加锁时,优化为间隙锁。
  2. 索引上的范围查询(唯一索引)–会访问到不满足条件的第一个值为止。
  3. 索引上的等值查询(普通索引),向右遍历时最后一个值不满足查询需求时,next-key lock 退化为间隙锁。

1.演示:索引上的等值查询 (唯一索引,例如主键索引)

  • 索引上的等值查询 (唯一索引,例如主键索引) ,给 不存在的记录 加锁时,优化为间隙锁。

  • 表中id为主键索引,我们给不存在的id=5加锁,此时就会在3和8之间加入一个 间隙锁
    在这里插入图片描述

  • 查询发现上了间隙锁

  • 查看查看意向锁及行锁的加锁情况:

select object schema,object name,index name,lock type,lock mode,lock data from performance schema.data locks;

在这里插入图片描述

  • 此时我们往(3-8)的间隙里加入数据(id=7),发现进入阻塞状态
    在这里插入图片描述

2.演示:索引上的范围查询(唯一索引)

  • 索引上的范围查询(唯一索引)–会访问到不满足条件的第一个值为止。
  • 我们针对既是主键也是唯一索引id,进行范围查询
    -
  • 查看锁情况
  • 查看查看意向锁及行锁的加锁情况:
select object schema,object name,index name,lock type,lock mode,lock data from performance schema.data locks;
  • 对19加了一个行锁S,REC_NOT_GAP
  • 对25与25之前间隙加了一个临键锁,S
  • 对25之后到正无穷supremum pseu加了临键锁,S
    在这里插入图片描述

3.演示:索引上的等值查询(普通索引)——临键锁退化为间隙锁

  • 索引上的等值查询(普通索引),向右遍历时最后一个值不满足查询需求时, 临键锁 退化为间隙锁 (可理解成多出一个间隙锁)
  • 前置知识: 我们加的行锁是针对索引加的锁,索引是一个B+树的结构,B+树的节点形成的是一个有序的双向链表
  • 现有的记录中有18,因为其不是唯一索引,18之前与之后将来都可能插入字段值为18的记录
    在这里插入图片描述
  • 于是乎16和18之间,18和29之间都会上锁;18和29之间是间隙锁,而16和18之间的临键锁,此时会退化为间隙锁;

我们可以看看下面这个例子:

  • 我们先对age加上普通索引
    在这里插入图片描述
  • 对age=3的记录,加上共享锁
    在这里插入图片描述
  • 我们查询锁的情况 注:S是临键锁
  • 查看查看意向锁及行锁的加锁情况:
select object schema,object name,index name,lock type,lock mode,lock data from performance schema.data locks;

在这里插入图片描述

  • 3,3是 临键锁S ,对应的是锁住3和3之前的部分在这里插入图片描述

  • 7,7是 临键锁S和 间隙锁GAP ,对应的是所著3和7之间的间隙在这里插入图片描述

  • 向右遍历时最后一个值不满足查询需求时, 临键锁 退化为间隙锁 (可理解成多出一个间隙锁)

四.表级锁

表级锁的基本概念&分类【表锁,元数据锁,意向锁】

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

对于表级锁,主要分为以下三类:

  1. 表锁
  2. 元数据锁
  3. 意向锁

【1】表锁

对于表锁,分为两类:

  1. 表共享读锁 (read lock)
  2. 表独占写锁 (write lock)

语法:

  1. 加锁: locktables 表名..read/write
  2. 释放锁: unlock tables/客户端断开连接

演示:

  • 加了读锁:其他包括自己客户端只能读不能写

在这里插入图片描述

【2】元数据锁:MDL

  • 元数据可以直接理解成: 表的结构
  • MDL加锁过程是系统 自动控制,无需显式使用 ,在访问一张表的时候会自动加上。MDL锁主要作用是维护表元数据的数据一致性,在表上有活动事务的时候,不可以对元数据进行写入操作
  • 在MySOL5.5中引入了MDL,当对一张表进行增删改查的时候,加MDL读锁(共享);当对表结构进行变更操作的时候,加MDL写锁(排他)。

不同SQL对应的元数据锁有所不同:
在这里插入图片描述

【3】意向锁

1.意向锁的由来

意向锁出现的场景:

  • 线程A:有一张表和客户端,我们开启事务,更新id为3的数据,会自动加上 行锁
    在这里插入图片描述

  • 此时,我们想给这张表上 表锁————显然,是做不到的,因为和原来的 行锁 冲突了
    在这里插入图片描述

  • 线程B:也就是我们想要加表锁前,就要先检查有无行锁;即 逐行检查 ,看下哪一行加了行锁, 这种方式性能很低
    -

  • 于是乎,为了提高性能,让我们在检查时不用 逐行检查 ——我们加入了 意向锁

意向锁加入以后的情况:

  • 线程A:有一张表和客户端,我们开启事务,更新id为3的数据,会自动加上 行锁
  • 在此基础上,再给表加上一个 意向锁
  • 线程B: 我们想加一个表锁,我们先看有无意向锁,再看所要加的表锁与原来的意向锁是否兼容(读/写锁) ,不兼容则进入阻塞状态,直到线程A提交

在这里插入图片描述

2.意向锁的相关语法(意向共享锁&意向排他锁)(包含语法和演示)

  1. 意向共享锁(IS): 与表锁共享锁(read)兼容 与表锁排它锁(write)互斥
  2. 意向排他锁(IX): 与表锁共享锁(read)及排它锁(write)都互斥 。意向锁之间不会互斥。

查看查看意向锁及行锁的加锁情况:

select object schema,object name,index name,lock type,lock mode,lock data from performance schema.data locks;

演示:
- 注:TABLE 为表锁 RECORD为行锁

在这里插入图片描述

  • 如何确定加共享锁是意向锁呢?输入查看代码
  • 我们可以看到lock_mode下面表锁对应的是IS,说明加的共享锁是意向共享锁

在这里插入图片描述

  • 我们知道,意向共享锁(IS): 与表锁共享锁(read)兼容 , 与表锁排它锁(write)互斥
  • 也就意味着此时可以加 表锁(读锁) ,而不能加 表锁(写锁)
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2077576.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Bytebase 2.22.2 - 允许在工作空间为群组分配角色

🚀 新功能 允许在工作空间给群组分配角色。 支持禁用邮箱密码登录,仅允许 SSO 登录的设置项。 新增 Postgres SQL 审核规则:禁止在列上设置会变化的默认值。 🔔 重大变更 下线项目内的变更历史页面;所有变更历史仍可…

Phoenix

Apache Phoenix 是一个开源的关系数据库层,运行在 Apache HBase 之上,旨在为 HBase 提供 SQL 查询能力和优化的存储引擎。它允许用户使用标准的 SQL 查询和事务语义来管理 HBase 中的数据,并且可以与现有的大数据生态系统无缝集成。Phoenix 通…

IOS开发 铃声制作(库乐队)

IOS开发,实现铃声制作功能。 在IOS端,要设置铃声都是通过库乐队来制作的。 先看一下库乐队中铃声的文件结构。下面是弄的一个示例的文件,文件信息如下: 我们右击文件,点击显示包内容如下: 能看到一个aiff格…

解决ssl certificates updated-生成环境中的实例

应原来小伙伴的要求,生产环境出错了,是harbor的ssl cert过期了,也因为使用的是免费的ssl证书,现在无法正常使用harbor,所以贴来了2023年1月曾经搭建的文档,希望能解决问题。^v^. -------------------------…

25 filedialog组件

Tkinter filedialog 组件使用指南 Tkinter 的 filedialog 组件提供了一个图形界面,用于打开和保存文件。它允许用户通过标准的文件选择对话框来选择文件,非常适合需要文件操作的GUI应用程序。以下是对 filedialog 组件的详细说明和一个使用案例。 file…

爆改YOLOv8 |YOLOv8融合SEAM注意力机制

1,本文介绍 SEAM(Spatially Enhanced Attention Module)是一个注意力网络模块,旨在解决面部遮挡导致的响应损失问题。通过使用深度可分离卷积和残差连接的组合,SEAM模块增强未遮挡面部的响应。深度可分离卷积在每个通…

Xshell 连接 Ubuntu 服务器失败问题(Connection failed)

目录 Xshell 连接 Ubuntu 服务器失败问题(Connection failed) 1.查看Ubuntu中是否安装 sshd 2.在Ubuntu中安装sshd 3.需要打开Ubuntu中新安装的sshd 4.在检查Ubuntu中sshd是否安装成功 5.临时关闭Ubuntu中的防火墙 6.Xshell 连接 Ubuntu 服务器成…

认知杂谈24

今天分享 有人说的一段争议性的话 I I 《人生逆袭的关键:开窍带来的转变》 在女人的生活里啊,最宝贝的东西可不是那些金银首饰啥的,也不只是那些起起落落的经历,更不是偶尔碰到的贵人帮忙。真正无价的,是在某个瞬间…

构建buildroot根文件系统

目录 1.确定gcc工具版本2.下载Buildroot源码并编译2.1 下载Buildroot源码2.2 配置Buildroot2.2.1 配置 Target options2.2.2 配置交叉编译工具链2.2.3 配置 System configuration2.2.4 配置 Filesystem images2.2.5 禁止编译 Linux 内核和 uboot2.2.6 编译Buildroot源码2.2.7 查…

Bootloader中的PBL、SBL的区别

从0开始学习CANoe使用 从0开始学习车载车身 相信时间的力量 星光不负赶路者,时光不负有心人。 目录 1.概述2.BootloaderPBLSBL3.SBL存在意义4.PBL存在意义 1.概述 应用软件和应用数据可以同时编程或者相互独立编程,不允许Boot Loader在软件运行时被非法…

透明度测试

1、透明测试是用于处理哪种透明需求 在游戏开发中对象的某些部位完全透明而其他部位完全不透明,这种透明需求往往不需要半透明效果,相对比较极端,只有看得见和看不见之分比如树叶、草、栅栏等等。(即一张图除了主要物体有颜色,其…

<WPF> xaml代码如何使用c#编写

<Window x:Class"grid面板的使用.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expression/blend/2008&…

【Java】—— Java面向对象基础:编程实例(学生信息管理)

目录 场景描述 定义学生类 创建学生对象并处理需求 代码解析 总结 在Java中&#xff0c;面向对象编程&#xff08;OOP&#xff09;是一种常用的编程范式&#xff0c;它允许我们创建基于现实世界的模型&#xff0c;通过类和对象来模拟这些模型。今天&#xff0c;我们将通过…

MySQL 集群技术全攻略:从搭建到优化(上)

目录 一.Mysql在服务器中的部署方法 1.在Linux下部署mysql 二.mysql的组从复制 1.当有数据时添加slave2 2.延迟复制 3.慢查询日志 4.mysql的并行复制 5.原理架构图 5.1三个线程 5.2复制三步骤 6.架构缺陷 三.半同步模式 1.半同步模式原理 2.gtid模式 3.启用半同…

数组、向量与矩阵

问题缘起 在看《矩阵力量》的时候&#xff0c;写到 利用 a numpy.array([4,3]). 严格说&#xff0c;此代码产生的不是行向量&#xff0c;运行 a.ndim 发现 a 只有一个维度。因此&#xff0c;转置 numpy.array([4,3]).T 得到的仍然是一维数组&#xff0c;只不过默认展示方式为…

腾讯提出一种新的针对风格化角色和逼真服装动画的生成3D运动转移方法,生成效果逼真!

来自腾讯XR视觉实验室的研究团队提出了一种创新的3D运动转移方法&#xff0c;专门针对风格化角色和逼真服装动画的生成。该方法能够将源动作准确地映射到目标角色上&#xff0c;同时考虑了角色身体的刚性变形和服装的局部物理动态变形。 与现有技术相比&#xff0c;这技术不仅…

探索分析文档布局,基于YOLOv8全系列【n/s/m/l/x】参数模型开发构建大规模文档数据集DocLayNet场景下文档图像布局智能检测分析识别系统

随着数字化和信息化的快速发展&#xff0c;大量的文档&#xff08;如合同、报告、表格、发票等&#xff09;以电子形式存在&#xff0c;这些文档中包含了丰富的信息。然而&#xff0c;这些信息往往以非结构化的形式存在&#xff0c;难以直接被计算机程序理解和处理。文档布局分…

8.26DEBUG

线程负责监听和处理不同的需求 顾客&#xff1a;代表需要被监控的文件句柄或网络socket&#xff0c;他们可能有各种需求&#xff0c;如点餐&#xff08;发送数据&#xff09;、询问菜品状态&#xff08;读取数据&#xff09;或需要帮助&#xff08;异常处理&#xff09; 菜单…

Android adb shell查看手机user,user_root,user_debug版本

Android adb shell查看手机user&#xff0c;user_root&#xff0c;user_debug版本 1、首先&#xff0c; adb shell 2、进入后&#xff0c;运行&#xff1a; getprop | grep ro.system.build.type 即会输出当前手机类型user,user_debug等。 另外&#xff0c;也可以运行&#…

NoSql数据库Redis集群

一、关系型数据库和 NoSQL 数据库 1.1 数据库主要分为两大类&#xff1a;关系型数据库与 NoSQL 数据库 关系型数据库 &#xff0c;是建立在关系模型基础上的数据库&#xff0c;其借助于集合代数等数学概念和方法来处理数据库中的数据主流的 MySQL 、 Oracle 、 MS SQL Server…