我的编程空间,编程开发者的网络收藏夹
学习永远不晚

一文读懂 MySQL 锁

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

一文读懂 MySQL 锁

1 MySQL 锁简介

1.1 什么是锁

锁是计算机用以协调多个进程间并发访问同一共享资源的一种机制。MySQL中为了保证数据访问的一致性与有效性等功能,实现了锁机制,MySQL中的锁是在服务器层或者存储引擎层实现的。

1.2 锁用来解决什么问题

锁是用来解决并发事务的访问问题,我们已经知道事务并发执行时可能带来的各种问题,最大的一个难点是:一方面要最大程度地利用数据库的并发访问,另外一方面还要确保每个用户能以一致的方式读取和修改数据,尤其是一个事务进行读取操作,另一个同时进行改动操作的情况下。

一个事务进行读取操作,另一个进行改动操作,我们前边说过,这种情况下可能发生脏读、不可重复读、幻读的问题。

怎么解决脏读、不可重复读、幻读这些问题呢?其实有两种可选的解决方案:

方案一:读操作MVCC,写操作进行加锁

该方案性能较好,但可能会读到旧版本记录

方案二:读写操作都加锁

该方案性能一般,但是每次都可以读取到最新的记录,比如在银行场景中,对安全性要求非常高

2 锁的分类

MySQL 中锁有很多,按照模式、粒度等可以分为如下几种类型

image-20221003154244472

3 乐观悲观锁

3.1 乐观锁

概念

乐观锁,顾名思义,就是非常乐观,乐观锁认为数据一般情况下不会造成冲突,所以在数据提交更新的时候才会去检测。

实现

乐观锁是基本版本号机制实现的,数据表中增加一个 version 字段,读取数据时将 version 一起读出。数据每更新一次,version 字段值 + 1。当修改需要提交时,将读取时的版本号与数据库当前版本号做比较,如果一致,说明在此期间无人修改这条记录,不一致则说明已经被修改了,提交失败。

适用场景

乐观锁适用于读操作多,写操作少的场景

3.2 悲观锁

概念

悲观锁是相比较乐观锁而言的,就是比较悲观,悲观锁认为数据每次操作都会被修改,所以在每次操作数据时都会加上锁。

实现

悲观锁通过共享锁和排他锁实现(下面会讲到这两种锁)

适用场景

适用于并发量不大,写操作多,读操作少的场景

4 共享排他锁

4.1 共享锁

概念

共享锁,又称读锁,简称 S 锁。当事务对数据加上读锁后,其他事务只能对该数据加读锁,不能加写锁。

实现

共享锁加锁方法:select …lock in share mode

image-20221003172941494

image-20221003173149274

4.2 排他锁

概念

排他锁,又称为写锁,简称 X 锁,当事务对数据加上排他锁后,其他事务无法对该数据进行查询或者修改

MySQL InnoDB引擎默认 update,delete,insert 都会自动给涉及到的数据加上排他锁,select 语句默认不会加任何锁类型。

实现

排他锁加锁方式:select …for update

image-20221003173825780

image-20221003173942828

5 粒度锁

5.1 全局锁

概念

全局锁,从名称上可以理解,全局锁就是对整个 MySQL 数据库实例加锁,加锁期间,对数据库的任何增删改操作都无法执行。

实现

MySQL 提供了一个加全局读锁的方法,命令是Flush tables with read lock (FTWRL)

适用场景

全库数据备份,可以使用全局锁,其他情况不要使用

5.2 表级锁

概念

表级锁,给当前操作的这张表加锁, MyISAM 与 InnoDB 引擎都支持表级锁定

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

实现

加表锁:lock table read/write

image-20221003175254955

image-20221003175706554

解除表锁:

找出被锁的表

show processlist

image-20221003180108421

kill 掉锁表的进程

kill 21;kill 22;

再次更新 user 表数据

image-20221003180453415

可以正常更新了

5.3 页级锁

页级锁是 MySQL 中锁定粒度介于行级锁和表级锁中间的一种锁。表级锁速度快,但冲突多,行级冲突少,但速度慢。因此,采取了折衷的页级锁,一次锁定相邻的一组记录。BDB 引擎支持页级锁

5.4 行级锁

概念

行级锁是 MySQL 粒度最细的锁,发生锁冲突概率最低,但是加锁慢,开销大

MySQL 中只有 InnoDB 引擎支持行锁,其他不支持

实现

MySQL 中,行级锁并不是之间锁记录,而是锁的索引。MySQL 在执行 update、delete 语句时会自动加上行锁

image-20221003181021358

image-20221003181133774

6 意向锁

概念

意向锁是表锁,为了协调行锁和表锁的关系,支持多粒度(表锁与行锁)的锁并存

作用

当有事务A有行锁时,MySQL会自动为该表添加意向锁,事务B如果想申请整个表的写锁,那么不需要遍历每一行判断是否存在行锁,而直接判断是否存在意向锁,增强性能。

兼容性

意向共享锁(IS)意向排他锁(IX)
共享锁兼容互斥
排他锁互斥互斥

7 间隙临键记录锁

概念

记录锁、间隙锁、临键锁都是排它锁,而记录锁的使用方法跟排它锁介绍一致。

7.1 记录锁

记录锁是封锁记录,记录锁也叫行锁,例如:

select * from user where id = 1 for update;

它会在 id=1 的记录上加上记录锁,以阻止其他事务插入,更新,删除 id=1 这一行。

7.2 间隙锁

间隙锁基于非唯一索引,它锁定一段范围内的索引记录。使用间隙锁锁住的是一个区间,而不仅仅是这个区间中的每一条数据

select * from user where id < 10 for update;

即所有在 [1,10)区间内的记录行都会被锁住,所有id 为 1、2、3、4、5、6、7、8、9 的数据行的插入会被阻塞

image-20221003182325290

image-20221003182340884

7.3 临键锁

临键锁,是记录锁与间隙锁的组合,它的封锁范围,既包含索引记录,又包含索引区间,是一个左开右闭区间。临键锁的主要目的,也是为了避免幻读(Phantom Read)。如果把事务的隔离级别降级为RC,临键锁则也会失效。

每个数据行上的非唯一索引列上都会存在一把临键锁,当某个事务持有该数据行的临键锁时,会锁住一段左开右闭区间的数据。需要强调的一点是,InnoDB 中行级锁是基于索引实现的,临键锁只与非唯一索引列有关,在唯一索引列(包括主键列)上不存在临键锁。

来源地址:https://blog.csdn.net/wgzblog/article/details/127281354

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

一文读懂 MySQL 锁

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

一文读懂 MySQL 锁

1 MySQL 锁简介 1.1 什么是锁 锁是计算机用以协调多个进程间并发访问同一共享资源的一种机制。MySQL中为了保证数据访问的一致性与有效性等功能,实现了锁机制,MySQL中的锁是在服务器层或者存储引擎层实现的。 1.2 锁用来解决什
2023-08-16

一文读懂IPSec

IPSec(Internet Protocol Security)是一种用于保护网络通信安全的协议。它通过加密和认证机制,确保数据在网络中传输时的机密性、完整性和身份验证。IPSec可以在两个通信的节点之间建立一个加密通道,以确保数据在传输
2023-09-21

一文读懂ActivityThread

ActivityThread是Android系统中的一个重要组件,它负责管理和调度应用程序中的Activity。在Android应用程序启动时,ActivityThread会被实例化,并成为应用程序的主线程。ActivityThread的主
2023-09-13

一文读懂JNDI

JNDI(Java Naming and Directory Interface)是Java提供的一种用于访问命名和目录服务的API。它允许开发人员在Java应用程序中使用统一的方式来访问各种命名和目录服务,包括LDAP(轻量级目录访问协议
2023-09-20

一文读懂 MySQL 中的索引

文章目录 1. 索引概述1.1 索引概述1.2 优点1.3 缺点1.6 常见索引概念1.6.1 聚簇索引1.6.2 二级索引(辅助索引、非聚簇索引)1.6.3 联合索引 1.8 MyISAM索引的原理1.9 MyISAM 与
2023-08-16

一文读懂navicat for mysql基础知识

目录一、数据库的操作二、数据类型三、备份和恢复三、操作动作四、高级五、知识补充一、数据库的操作 1、新建数据库2、打开数据库 右键或者双击就可以了。 3、删除数据库 右键?>删除数据库 4、修改数据库 右键?>数据库属性 二、数据类型 1、
2022-05-13

一文读懂EVPN技术

EVPN(Ethernet Virtual Private Network)是一种新兴的以太网虚拟专用网络技术,可以提供灵活、可靠、可扩展的以太网VPN服务。EVPN的核心思想是将以太网MAC地址学习和转发与BGP(Border Gatew
2023-09-20

一文读懂 Java Memory Model:解锁并发编程中的疑惑

Java Memory Model (JMM) 是理解并发编程中内存一致性的关键。它定义了多线程程序中共享变量的可见性、有序性等规则,掌握 JMM 有助于解决并发编程中的疑惑,编写更健壮的代码。
一文读懂 Java Memory Model:解锁并发编程中的疑惑
2024-02-04

一文带你读懂Java IO复用

本篇文章为大家展示了一文带你读懂Java IO复用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。对于服务器的并发处理能力,我们需要的是:每一毫秒服务器都能及时处理这一毫秒内收到的数百个不同TCP连接
2023-05-31

一文搞懂Mysql中的共享锁、排他锁、悲观锁、乐观锁及使用场景

目录一、常见锁类型二、mysql引擎介绍三、常用引擎间的区别 四、共享锁与排他锁五、排他锁的实际应用六、共享锁的实际应用七、死锁的发生八、另一种发生死锁的情景九、死锁的解决方式十、意向锁和计划锁十一、乐观锁和悲观锁总结一、常见锁类型表级锁
2022-07-04

编程热搜

目录