MySQL学习3之锁机制

一、什么是锁粒度

锁粒度(Lock Granularity)是指在数据库锁定数据资源的最小单位锁粒度决定了锁定操作的范围,即锁定的是整个数据库、整个表、表中的某个分区、表中的某一页还是表中的某一行。

在MySQL中常见的锁粒度有:表级锁、行级锁、页级锁。

因为更细粒度的锁可以允许更多的并发事务访问不同的数据资源,所以锁粒度越小,锁的竞争越小,并发性能越高,锁管理的开销越大。合理选择锁粒度可以帮助平衡锁的竞争和并发性能,从而提高数据库的整体性能。

二、MySQL中常见的锁粒度类型

2.1、表级锁:

  • 描述:锁定整个表,阻止其他事务访问该表。
  • 用途:适用于需要锁定整个表的场景,例如 MyISAM 和 MEMORY 存储引擎。
  • 特点:锁的竞争最小,但并发性能较低。

2.2、行级锁:

  • 描述:锁定特定的行,而不是整个表。
  • 用途:适用于需要锁定单个行的场景,以减少锁的竞争。
  • 特点:锁的竞争较大,但并发性能较高。

2.3、页级锁:

  • 描述:锁定数据页,而不是行或整个表。
  • 用途:适用于需要锁定数据页的场景,例如在某些存储引擎中用于索引组织表。
  • 特点:锁的竞争和并发性能介于表级锁和行级锁之间。

一般来说,如果事务主要涉及读操作,可以选择较大的锁粒度(如表级锁),以减少锁的管理开销。如果事务涉及大量写操作,并且写操作通常是针对少量行的,那么使用较小的锁粒度(如行级锁)可以提高并发性能。

三、如何设置锁粒度

在 MySQL 中,锁粒度通常是由存储引擎自动管理的。不同的存储引擎支持不同类型的锁。通常,不需要显式设置锁粒度,通过选择合适的存储引擎和事务隔离级别来间接控制锁的行为。

3.1、选择存储引擎

  • InnoDB 存储引擎:默认支持行级锁,适用于需要高并发和事务安全的场景。
  • MyISAM 存储引擎:支持表级锁,适用于读多写少的场景

3.2、选择事务隔离级别

  • READ UNCOMMITTED:最低的隔离级别,不使用行级锁,可能导致脏读。
  • READ COMMITTED:使用行级锁,允许并发读取,但可能导致不可重复读。
  • REPEATABLE READ(默认):使用行级锁,禁止并发读取,避免不可重复读。
  • SERIALIZABLE:最高隔离级别,使用表级锁,确保事务串行执行。

一旦表创建完成,锁粒度就已经确定。如果需要更改锁粒度,你需要重新创建表或使用不同的存储引擎。

四、锁模式

4.1、共享锁(Shared Locks,S锁)

  • 描述:允许多个事务同时读取数据,但阻止其他事务写入数据。
  • 用途:适用于读取数据的场景。
  • 示例:在 InnoDB 中,SELECT ... LOCK IN SHARE MODE 会获取共享锁。

4.2、排他锁(Exclusive Locks,X锁)

  • 描述:阻止其他事务读取或写入数据。
  • 用途:适用于写入数据的场景。
  • 示例:在 InnoDB 中,SELECT ... FOR UPDATE 会获取排他锁。

4.3、意向锁(Intention Locks)

  • 描述:意向锁是一种特殊的锁,用于指示事务打算获取的锁的类型。
  • 用途:用于与其他锁协调,以减少死锁的可能性。
  • 示例:意向共享锁(IS)表示事务打算获取共享锁,意向排他锁(IX)表示事务打算获取排他锁。

五、锁等待

5.1、什么是锁等待

锁等待(Lock Wait)是指在数据库事务处理中,当一个事务请求锁定某个资源(如行、页或表)时,如果该资源已经被另一个事务锁定,则请求锁定的事务将进入等待状态,直到资源解锁为止。这种等待状态称为锁等待

5.2、锁等待的影响

  • 并发性能锁等待可能会降低系统的并发性能,因为等待的事务无法继续执行。
  • 死锁:如果多个事务互相等待对方释放锁,则可能导致死锁。

5.3、锁等待的检测与解决

  • InnoDB 存储引擎:InnoDB 存储引擎会自动检测锁等待情况,并在必要时报告锁等待状态。
  • 等待超时:可以通过设置 innodb_lock_wait_timeout 参数来限制等待锁的时间,超过该时间后事务将回滚。
  • 死锁检测:MySQL 会自动检测死锁,并回滚其中一个事务以解决死锁。

5.4、锁等待的预防

  • 合理的事务设计:尽量减少事务的持续时间和锁定资源的数量。
  • 事务隔离级别:选择合适的事务隔离级别以减少锁等待
  • 锁的粒度:使用更细粒度的锁(如行级锁)可以减少锁等待的机会。

六、死锁检测与处理

在执行需要锁定数据的操作时,MySQL 会自动获取相应的锁。在事务提交或回滚时,MySQL 会自动释放所有锁定的数据资源。

在 MySQL 中,死锁是指两个或多个事务互相等待对方释放锁,从而形成循环等待的情况。当这种情况发生时,MySQL 会自动检测并解决死锁问题

MySQL 会检测死锁情况,当发现死锁时,会自动回滚其中一个事务以解决死锁。MySQL 通常会选择回滚成本较低的事务,以减少对系统的影响。

6.1、死锁检测

MySQL 的 InnoDB 存储引擎会自动检测死锁。InnoDB 使用了一个称为“等待图”的数据结构来检测死锁。每当事务请求一个新的锁时,InnoDB 会在等待图中添加一条边,表示事务正在等待锁。如果等待图中形成了一个环路,则表明存在死锁。

6.2、死锁处理

当检测到死锁时,MySQL 会采取措施来解决死锁。通常的做法是选择一个事务进行回滚,以打破循环等待的情况。InnoDB 通常会选择回滚成本较低(基于事务的大小、回滚成本和优先级等因素确定)的事务,以减少对系统的影响。


http://www.ppmy.cn/devtools/95646.html

相关文章

mac如何恢复被同名替换掉的文件夹 mac文件被替换如何恢复

Mac系统一直以高性能遥遥领先其他的Windows系统,因此,Mac虽然价格远远高出其他的笔记本电脑,但是还是受到了一众用户的青睐。使用mac时,我们也经常会将一个文件命名为已经有了相同文件的文件名,且保存到同一个目标地址…

jave2、ffmpeg 的安装以及实现音频切分功能

jave2、ffmpeg 实现音频切分功能 关于 ffmpeg 的安装mac 下安装 ffmpegdocker 和 linux 下安装 ffmpeg 关于 ffmpeg 使用在命令行使用在 java 代码中使用 关于 javacv、ffmpeg-platform 的使用 背景是需要在 java 项目中实现一个音频切分的功能,比如用户上传了一个1…

如何将excel以文本形式储存的数字一键转换为数字

有时候一些软件给出的数据格式很恶心,为了方便计算常常以数字粘贴到新表,但随之而来新问题,以文本储存的公式无法用公式计算,怎么办啊 方法一:使用“转换为数字”功能 (对数字少时用) 当Excel检测到某个单…

MySQL 主从复制的过程

MySQL 主从复制,其线程和过程分析 Master ->Slave IO_Thread (单线程)->Slave Relay log -> Slave SQL_Thread (单线程,每次等待所有Worker线程处理完毕之后才重新拉取新binlog)->Slave_Coordinator - >Slave_Worker (parallel_worker)&…

【Qt】Qt窗口 | QStatusBar 状态栏

文章目录 一. 状态栏二. 代码创建&使用状态栏1. 创建状态栏2. 在状态栏中显示实时消息3. 在状态栏中显示控件 一. 状态栏 状态栏是应用程序中输出简要信息的区域,通常位于窗口的底部,用于显示应用程序的状态信息或提供用户与应用程序交互的反馈。一…

PROCESSING_ORDER

PROCESSING_ORDER属性决定XDC文件是否将由 Vivado Design Suite在约束处理期间,或正常处理,或延迟处理。 PROCESSING_ORDER可以是:早期、正常或晚期。 默认情况下,Vivado Design Suite在用户XDC文件之前读取IP核的XDC文件 在顶层设…

SSH升级至9.8p1

此前写过一个有关升级ssh的帖子,当时的情况是ssh5.3p1 升级到 ssh8.0 p1 下面是链接:https://blog.csdn.net/zhurobert/article/details/103193205?spm1001.2014.3001.5501 此次升级的环境是CentOS-7.6.1810 ssh版本7.4p1 准备好升级包后上传至/home…

Redis远程字典服务器(7)—— set类型详解

目录 一,基本情况 二,常用命令 2.1 sadd 2.2 smembers,sismember 2.3 spop,srandmember 2.3 smove,srem 2.4 sinter,sinterstore求交集 2.5 sunion,sunionstore求并集 2.6 sdiff&#…

2024网络安全学习路线 非常详细 推荐学习

关键词:网络安全入门、渗透测试学习、零基础学安全、网络安全学习路线 首先咱们聊聊,学习网络安全方向通常会有哪些问题 1、打基础时间太长 学基础花费很长时间,光语言都有几门,有些人会倒在学习 linux 系统及命令的路上&#…

Linux的awk使用方式

awk 编辑器 流编辑器 擅长处理列 读入一行 执行一次主输入循环 语法 # awk 选项 {} 文件名{} 主输入循环print 打印字符串 必须加引号 数字 不能加引号 变量 不能加引号 [rootweb ftp]# awk {print "abc"} a.txt abc abc abc abc abc# awk {abc8;print a…

零售业务产品系统应用架构设计(二)

ETC信用结算系统根据《加快推进高速公路电子不停车快捷收费应用服务实施方案》(发改基础〔2019〕935号),拓宽ETC发行服务渠道。推动建立全网协同服务模式,完善服务规则,鼓励银行业金融机构、非银行支付机构和互联网企业等服务机构紧密合作。允许ETC绑定既有银行账户和支付…

微前端架构下的负载均衡实现:策略与技术

微前端架构通过将一个庞大的前端应用拆分成多个小型、独立的子应用,提高了开发效率和应用的可维护性。然而,随着用户访问量的增加,单个子应用可能会面临性能瓶颈。负载均衡作为解决这一问题的关键技术,可以有效地分配用户请求到多…

选择排序(附动图)

1.思路 基本思想: 每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完 。 1.1双向选择排序(升序) 头尾指针(索引&#xf…

redis事件机制

redis服务器是一个由事件驱动(死循环)的程序,它总共就干两件事: 文件事件:利用I/O复用机制,监听Socket等文件描述符发生的事件,如网络请求时间事件:定时触发的事件,负责完成redis内部定时任务&…

Go语言基础--数据类型(布尔、字符串)

布尔类型 Go语言的布尔类型非常直接,只有两个值:true 和 false。它常用于控制流语句(如if和for)的条件表达式中。 package main import ( "fmt" "unsafe" ) func main() { var b bool false f…

《向量数据库指南》——AI应用长文本与RAG通用对比

长文本与RAG通用对比 准确率:通常情况下长文本优于RAG 长文本:可更加综合的去分析所有相关的内容,提取相关数字,生成图表,效果尚可。 RAG:更适合找到一段或者是几段可能相关的段落。如果希望大模型能够对问题有全局的认识,比较困难。如,根据上市公司的2020年财务报表,…

dev c++中,在C++11模式下编译带M_PI宏的文件报错的解决办法

一、问题描述 当使用C11的模式,编译引用了math库中的M_PI的源文件时,报M_PI未声明的错误。 二、问题原因 因为M_PI是GNU扩展的宏,它不属于C11的标准,而-stdc11,表示以C11的标准进行编译,因此会产生以上问…

string模拟

本章准备对string模拟进行讲解,以下是string的学习网址: string - C Reference (cplusplus.com) string本质可以理解为储存char类型的顺序表,其中string的迭代器用一个char*就可以解决。所以string类成员变量如下: 这里用了一个命…

Datawhale X 魔搭 AI夏令营第四期魔搭-AIGC文生图方向Task3笔记

Task3:进阶上分-实战优化 part1:工具初探一ComfyUI应用场景探索 ComfyUI概述 ComfyUI是一个功能强大、高度模块化的Stable Diffusion图形用户界面和后端系统,它允许用户通过链接不同的节点来构建复杂的图像生成工作流程。这些节点可以包括各…

Ubuntu系统的基础操作和使用

Ubuntu系统的基础操作和使用 Ubuntu是一种流行的开源操作系统,基于Linux内核,由南非商业人士马克舍特尔沃斯创立,旨在为用户提供一种免费、易用且开放的操作系统解决方案。Ubuntu以其强大的稳定性、安全性和广泛的社区支持而广受欢迎。本文将…