MySQL 锁概述
1.锁的分类
根据不同的分类角度可将锁分为:
- 按是否共享分:S 锁、X 锁
- 按粒度分:表级锁、行级锁、全局锁(锁整个库)、页锁(锁数据页)
- 意向锁:意向 S 锁、意向 X 锁:都是表级锁,且 IS 和 IX 之间不互斥。IS 锁和 IX 锁的使命只是为了后续在加表级别的 S 锁和 X 锁时判断表中是否有已经被加锁的记录,以避免用遍历的方式来查看表中有没有上锁的记录。
- MDL 锁(元数据锁)
InnoDB 的表级锁比较鸡肋,一般不会被用到,重点在于理解 InnoDB 的行级锁。
InnoDB 常见行级锁:
- Record Locks(正经记录锁):可以加上 S 锁或 X 锁。
- Gap Locks(间隙锁):用于防止数据插入,解决了可重复读隔离级别下幻读的问题。
- Next-Key Locks(临键锁):等价于 正经记录锁 + 间隙锁
- Insert Intention Locks(插入意向锁):其实就是 MySQL 的设计者规定事务发生时需要在内存中获取一个锁,而现在这个事务正好是为了插入数据,所以锁的类型就定为插入意向锁了。
- 隐式锁:面对事务 T1 中插入了一条记录,该记录上没有任何锁。此时,其他的事务对该记录进行读写时就可能产生脏读或脏写的问题。为此,InnoDB 通过事务 id 来判断当前事务是否处于活跃状态,如果是处于活跃状态的,则会自动加上 X 锁。(因为写操作都会加 X 锁,所以写操作都是针对最新的记录的)
按锁的态度分:
-
悲观锁:
悲观锁是一种思想,顾名思义,就是很悲观,对数据被其他事务的修改持保守态度,会通过数据库自身的锁机制来实现,从而保证数据操作的排它性。悲观锁总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会锁,这样别人再去操作这个数据时就会被阻塞直到它拿到锁(共享资源每次只给一个线程使用,其它线程阻塞,用完后再把资源转让给其它线程)。比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁,当其他线程想要访问数据时,都需要阻塞挂起。Java 中 synchronized 和 ReentrantLock 等独占锁也是悲观锁思想的实现。悲观锁的特点意味着它适合写操作较多,且并发量较小的场景。
-
乐观锁:
乐观锁认为对同一数据的并发操作不会总发生,属于小概率事件,不用每次都对数据上锁。但为保证数据的安全性,还是会在更新的时候会判断一下在此期间别人有没有去更新这个数据,这点不是采用数据库自身的锁机制,而是通过程序来实现。在程序上,我们可以采用版本号机制或者CAS机制实现。Java 中的 java.util.concurrent.atomic 包下的原子变量类就是使用了乐观锁的一种实现方式:CAS 实现的。**乐观锁的特点也意味着它适用于读操作较多的场景,**这样可以提高吞吐量。
小贴士:
乐观锁和悲观锁并不是锁,而是锁的设计思想 。
死锁:
死锁是指两个或多个事务在同一资源上相互占用,并请求锁定对方占用的资源,但互不相让,导致双方进入无休止的等待。
产生死锁的必要条件:
- 存在两个或者两个以上的事务;
- 每个事务都已经持有锁,且在申请另一个锁;
- 一个锁资源同时只能被同一个事务持有;
- 事务之间因为各自持有双方要的另一个锁,而彼此等待;
死锁的关键在于:两个或以上的事务获取锁的顺序不一样,比如事务 T1 要先获取锁 A 再获取锁 B,而事务 T2 要先获取锁 B 再获取锁 A。如果大家都是先获取锁 A,再获取锁 B,那就不会有死锁问题。
死锁的解决方案:
-
方案一:事务直接进入等待,直到超时;
-
方案二:发起死锁检测,发现死锁后,主动回滚死锁链条中的某一个事务,让其他事务得以继续执行;
但由于上述方案都存在一定的局限性,比如方案一可能造成长时间的等待,方案二可能消耗较多 CPU 资源去做死锁检测(比如有 1000 个事务,就要做 1000 * 1000 次检测)。因此还可以考虑下面的方案:
- 合理设计索引,使业务 SQL 尽可能通过索引定位更少的行,减少锁竞争;
- 调整业务逻辑 SQL 执行顺序,避免 update/delete 长时间持有锁的 SQL在事务前面;
- 避免大事务,尽量将大事务拆成多个小事务来处理,通过小事务缩短锁定资源的时间,发生锁冲突的几率也更小;
- 在并发比较高的系统中,不要显式加锁,特别是在事务里显式加锁。如 select…for update 语句,在该事务提交前,其他事务需要等待该事务释放锁;
- 降低隔离级别。如果业务允许,可以将隔离级别调低,比如从 RR 调为 RC,可以避免掉很多因为 gap 锁造成的死锁;
2.锁的内存结构
在多个未提交事务相继对一条记录做改动时,需要让它们排队执行,这个排队的过程其实是通过锁来实现的。而对一条记录加锁的本质就是在内存中创建一个锁结构与之关联(事务执行时才会创建)。

如上图所示,当一个事务想对一条记录做改动时,首先会看看内存中有没有与这条记录关联的锁结构,当没有的时候就会在内存中生成一个锁结构与之关联。比方说事务 T1 要对这条记录做改动,就需要生成一个锁结构与之关联。为了方便理解,我们对锁的结构进行了简化,仅保留 3 个重要属性:
- trx 信息:代表这个锁是哪个事务创建的
- is_waiting:False 代表获取锁成功,True 代表获取锁失败
- type:代表锁的类型
在上面的例子中,当事务 T1 改动了这条记录后,就生成了一个锁结构与该记录关联,因为之前没有别的事务为这条记录加锁,所以is_waiting 属性就是 false,我们把这个场景就称之为获取锁成功,或者加锁成功,然后就可以继续执行操作了。
对于事务 T2,由于事务 T1 还占用着锁,且锁的类型是 X 锁。因此事务 T2 生成的锁结构中的 is_waiting 属性为 True,代表它需要等待事务 T1 释放锁后才能执行。
3.一致性读与当前读
在 MySQL 中,读操作可以分为快照读(又称一致性读、一致性无锁读)和当前读(又称锁定读)。快照读读取的是记录的可见版本(可能是历史版本),不需要加锁;而当前读读取的是记录的最新版本,并且当前读返回的记录会加上锁(S 锁或 X 锁),以保证其他事务不会再并发修改这条记录。
因此,当一条记录加上锁后,其他事务仍然可以进行快照读操作,因为快照读不需要获取锁。
参考
- 《MySQL 是怎样运行的》
- 《MySQL 45 讲》
相关文章:
MySQL 锁概述
1.锁的分类 根据不同的分类角度可将锁分为: 按是否共享分:S 锁、X 锁按粒度分:表级锁、行级锁、全局锁(锁整个库)、页锁(锁数据页)意向锁:意向 S 锁、意向 X 锁:都是表…...
springboot502基于WEB的牙科诊所管理系统(论文+源码)_kaic
牙科诊所管理系统的设计与实现 摘要 近年来,信息化管理行业的不断兴起,使得人们的日常生活越来越离不开计算机和互联网技术。首先,根据收集到的用户需求分析,对设计系统有一个初步的认识与了解,确定牙科诊所管理系统的…...
overleaf中出现TeX capacity exceeded PDF object stream buffer=5000000的原因和解决方案
在插入pdf 配图后,编译出错提示信息如图,很可能的一个原因是pdf文件大小太大了,最好压缩一下,压缩到1MB以内。...
LabVIEW神经肌肉电刺激与记录系统
神经肌肉电刺激技术在康复医学和神经科学领域占有重要地位。基于LabVIEW开发了神经肌肉电刺激与记录系统,该系统具备可控电脉冲输出与高效数据采集功能,适用于临床和科研领域。 项目背景 神经肌肉电刺激技术用于治疗各类神经和肌肉系统疾病,…...
【CSS in Depth 2 精译_096】16.4:CSS 中的三维变换 + 16.5:本章小结
当前内容所在位置(可进入专栏查看其他译好的章节内容) 第五部分 添加动效 ✔️【第 16 章 变换】 ✔️ 16.1 旋转、平移、缩放与倾斜 16.1.1 变换原点的更改16.1.2 多重变换的设置16.1.3 单个变换属性的设置 16.2 变换在动效中的应用 16.2.1 放大图标&am…...
Label-Studio X SAM 半自动化标注
教程:playground/label_anything/readme_zh.md at main open-mmlab/playground GitHub B站视频:Label Studio x Segment Anything Model 半自动化标注_哔哩哔哩_bilibili 需要注意: 1.LINUX上跑比较方便 2.中文路径、文件名闯大祸 3. 4…...
Mono里运行C#脚本8—mono_image_storage_open打开EXE文件
Mono里运行C#脚本8—mono_image_storage_open打开EXE文件 前面分析哈希表的实现,以及文件打开的底层函数,还有保存到HASH表里的数据结构。 static MonoImageStorage * mono_image_storage_open (const char *fname) { char *key = NULL; key = mono_path_resolve_symlinks…...
【WebSocket】tomcat内部处理websocket的过程
websocket请求格式 浏览器请求 GET /webfin/websocket/ HTTP/1.1。 Host: localhost。 Upgrade: websocket。 Connection: Upgrade。 Sec-WebSocket-Key: xqBt3ImNzJbYqRINxEFlkg。 Origin: http://服务器地址。 Sec-WebSocket-Version: 13。 服务器响应 HTTP/1.1 101 Swi…...
将一个组件的propName属性与父组件中的variable变量进行双向绑定的vue3(组件传值)
封装组件看这个,然后理解父子组件传值 应用场景: 1.使用v - model语法实现双向绑定(传值两边都不用定义方法接数据) 1.子组件 1. update:modelValue事件是MultiSelect组件对象自带的事件 2.:options"countries" opti…...
Linux下通用型shellcode的编写
实验目的及要求 目的: 通过对本实验执行过程的理解,认真分析总结,能够独立的在 Linux 下进行 shellcode 的编写。 要求: (1)%70:完成对 shellcode 的分析及提取 (2)%…...
STM32F103RCT6学习之二:GPIO开发
GPIO基础 1.简介 2.GPIO基本结构 3.种模式 GPIO基本功能 1.输出功能--LED灯闪烁 1)进行基本配置 2)编辑代码 主要在main.c中编辑。 int main(void) {/* USER CODE BEGIN 1 *//* USER CODE END 1 *//* MCU Configuration------------------------------------------------…...
kong网关使用pre-function插件,改写接口的返回数据
一、背景 kong作为api网关,除了反向代理后端服务外,还可对接口进行预处理。 比如本文提及的一个小功能,根据http header某个字段的值,等于多少的时候,返回一个固定的报文。 使用到的kong插件是pre-function。 除了上…...
C++、Python有哪些相同和不同
C 和 Python 是两种流行的编程语言,设计理念和应用场景各有不同,但也有一些相似之处。以下是它们在语言特性、性能、语法等方面的相同点和不同点的比较: 相同点 支持多种编程范式: 面向对象编程 (OOP):两者都支持类、继…...
Spring Boot 自动配置:从 spring.factories 到 AutoConfiguration.imports
Spring Boot 提供了强大的自动配置功能,通过约定优于配置的方式大大简化了应用开发。随着版本迭代,自动配置的实现方式也逐渐优化,从早期的 spring.factories 文件到最新的 META-INF/spring/org.springframework.boot.autoconfigure.AutoConf…...
HarmonyOS Next 应用元服务开发-应用接续动态配置迁移按需退出
按需退出,支持应用动态选择迁移成功后是否退出迁移源端应用(默认迁移成功后退出迁移源端应用)。如果应用不想让系统自动退出迁移源端应用,则可以设置不退出,参数定义见SUPPORT_CONTINUE_SOURCE_EXIT_KEY。 示例&#x…...
SQL-leetcode-180. 连续出现的数字
180. 连续出现的数字 表:Logs -------------------- | Column Name | Type | -------------------- | id | int | | num | varchar | -------------------- 在 SQL 中,id 是该表的主键。 id 是一个自增列。 找出所有至少连续出现三次的数字。 返回的…...
使用Python pickle模块进行序列化
使用Python pickle模块进行序列化 在Python中,pickle模块是一个用于实现数据序列化与反序列化的强大工具。与json模块不同的是,pickle支持将几乎所有的Python对象进行序列化,包括字典、列表、类实例,甚至函数。这使得它在处理复杂…...
责任链模式(ChainofResponsibilityPattern)
文章目录 1.定义2.结构3.问题描述代码实现 1.定义 允许你将请求沿着处理者链进行发送。 收到请求后, 每个处理者均可对请求进行处理, 或将其传递给链上的下个处理者。 2.结构 处理者(Handler):声明了所有具体处理者的通用接口。 该接口通常…...
自定义 Element Plus 树状表格图标
在开发使用 Element Plus 的树状表格时,默认的展开/收起图标可能不能满足设计需求。为了更符合项目要求,可以通过覆盖样式的方式来自定义这些图标。以下记录了实现自定义树状表格图标的完整过程。 实现效果 有子节点且未展开时:显示一个加号…...
Vue2:用一个例子理解一下vue template中属性前面的冒号“:“
常用写法 table中绑定数据,我们通常这么写: <el-table :data="tableData" style="width: 100%">data() {tableData:[], } data绑定变量名可变的动态对象 但是上一篇文中,因为要生成15组相似的table,它们的格式都一样,只是数据…...
AF3 partition_tensor函数源码解读
该函数将输入张量按原子维度 (n_atoms) 分块,以局部窗口方式滑动,生成 滑动窗口张量。 在神经网络中,尤其是处理大规模序列数据(例如蛋白质原子特征)时,直接对整个序列执行操作可能会导致计算和内存效率问题。partition_tensor 函数通过对输入张量进行分块(partitions)…...
C++类与对象上
1.面向过程和面向对象初步认识 C语言是面向过程的,关注的是过程,分析出求解问题的步骤,通过函数调用逐步解决问题 例如洗衣服: C是基于面向对象的,关注的是对象,讲一件事拆分成不同的对象,靠对…...
中巨伟业推出高安全高性能32位智能卡内核可编程加密芯片SMEC88SP/ST
1、产品特性 以最高安全等级的智能卡芯片内核为基础,具有极高的软硬件安全性 实现客户关键功能或算法代码下载,用户可以灵活实现自有知识产权的保护 标准 SOP8、SOT23-6 封装形式,器件封装小 标准 I2C 接口,具有接…...
Python微博动态爬虫
本文是刘金路的《语言数据获取与分析基础》第十章的扩展,详细解释了如何利用Python进行微博爬虫,爬虫内容包括微博指定帖子的一级评论、评论时间、用户名、id、地区、点赞数。 整个过程十分明了,就是用户利用代码模拟Ajax请求,发…...
包管理工具npm、yarn、pnpm、cnpm详解
1. 包管理工具 1.1 npm # 安装 $ node 自带 npm# 基本用法 npm install package # 安装包 npm install # 安装所有依赖 npm install -g package # 全局安装 npm uninstall package # 卸载包 npm update package # 更新包 npm run script #…...
Docker和Kubernetes(K8s)区别
目录 1. Docker Docker 的核心概念: Docker 的功能: Docker 常见使用场景: 2. Kubernetes (K8s) Kubernetes 的核心概念: Kubernetes 的功能: Kubernetes 常见使用场景: 3.Docker 和 Kubernetes 的…...
龙智出席2024零跑智能汽车技术论坛,分享功能安全、需求管理、版本管理、代码扫描等DevSecOps落地实践
龙智快讯 2024年12月5日,由零跑和盖世汽车主办的“2024零跑智能汽车技术论坛”在杭州零跑总部圆满落幕。此次技术论坛聚焦AI语言大模型、AUTOSAR AP平台、DevOps、端到端自动驾驶等热点话题展开探讨,旨在推动智能汽车技术的创新与发展。 龙智作为国内领先…...
SQL进阶技巧:如何分析双重职务问题?
目录 0 背景描述 1 数据准备 2 问题分析 方法2:利用substr函数,充分利用数据特点【优秀解法】 3 小结 0 背景描述 在 CompuServe 刚成立时,Nigel Blumenthal 遇到一个应用程序中的困难。他需要获取公司人员所担任角色的源表,…...
SAQ问卷的定义,SAQ问卷是什么?
SAQ问卷,全称为可持续发展评估问卷(Sustainability Assessment Questionnaire),是一种在线自评工具,其深远意义与广泛应用在当今商业环境中愈发凸显。它不仅是一种衡量企业在环境、社会和治理(ESGÿ…...
Express.js 有哪些常用的中间件?
在使用 Express.js 开发应用程序时,中间件(Middleware)是处理请求和响应的关键组件。它们可以执行各种任务,如解析请求体、添加HTTP头部、记录日志等。以下是一些常用的中间件: body-parser 用于解析传入的请求体。它…...
K8s DaemonSet的介绍
1. 什么是 DaemonSet? DaemonSet 是 Kubernetes 中的一种控制器,用于确保每个(或某些指定的)节点上运行一个 Pod 副本。它是为部署守护进程设计的,例如需要在每个节点上运行的任务或工具。 特点: Pod 会随…...
同步异步日志系统:设计模式
设计模式是前辈们对代码开发经验的总结,是解决特定问题的⼀系列套路。它不是语法规定,⽽是⼀ 套⽤来提⾼代码可复⽤性、可维护性、可读性、稳健性以及安全性的解决⽅案。 为什么会产生设计模式这样的东西呢?就像人类历史发展会产生兵法。最开…...
【GO基础学习】Gin 框架中间件的详解
文章目录 中间件详解中间件执行全局中间件路由级中间件运行流程中间件的链式执行中断流程 代码示例 gin框架总结 中间件详解 Gin 框架中间件是其核心特性之一,主要用于对 HTTP 请求的处理进行前置或后置的逻辑插入,例如日志记录、身份认证、错误处理等。…...
ubuntu停止.netcore正在运行程序的方法
在Ubuntu系统中停止正在运行的.NET Core程序,你可以使用以下几种方法: 使用kill命令: 如果你知道.NET Core程序的进程ID(PID),你可以直接使用kill命令来停止它。首先,使用ps命令配合grep来查找.…...
图神经网络_图嵌入_Struc2Vec
0 背景 之前的node embedding方式,都是基于近邻关系,但是有些节点没有近邻,也有结构相似性。如图中的u、v节点。 struc2vec算法适用于捕获结构相似性。 1 相似度(距离)计算 1.1 公式 f k ( u , v ) f k − 1 ( u …...
LabVIEW应用在工业车间
LabVIEW作为一种图形化编程语言,以其强大的数据采集和硬件集成功能广泛应用于工业自动化领域。在工业车间中,LabVIEW不仅能够实现快速开发,还能通过灵活的硬件接口和直观的用户界面提升生产效率和设备管理水平。尽管其高成本和初期学习门槛可…...
js-000000000000
1、js书写的位置 - 内部 <body> <!-- 习惯把 js 放到 /body 的后面 --> <script> console.log(这是内部 js 的书写位置) alert(内部js) </script> </body> <body><!-- 习惯把 js 放到 /body 的后面 --><script>console.log(这…...
【微信小程序】3|首页搜索框 | 我的咖啡店-综合实训
首页-搜索框-跳转 引言 在微信小程序中,首页的搜索框是用户交互的重要入口。本文将通过“我的咖啡店”小程序的首页搜索框实现,详细介绍如何在微信小程序中创建和处理搜索框的交互。 1. 搜索函数实现 onClickInput函数在用户点击搜索框时触发&#x…...
虚幻引擎是什么?
Unreal Engine,是一款由Epic Games开发的游戏引擎。该引擎主要是为了开发第一人称射击游戏而设计,但现在已经被成功地应用于开发模拟游戏、恐怖游戏、角色扮演游戏等多种不同类型的游戏。虚幻引擎除了被用于开发游戏,现在也用于电影的虚拟制片…...
分布式光纤传感|分布式光纤测温|线型光纤感温火灾探测器DTS|DTS|DAS|BOTDA的行业16年的总结【2024年】
背景: 从2008年,从事分布式光纤传感行业已经过了16年时间了,依稀记得2008年,看的第一遍论文就是中国计量大学张在宣老爷子的分布式光纤测温综述,我的经历算是行业内极少数最丰富的之一。混过学术圈: 发表…...
【无标题】学生信息管理系统界面
网页是vue框架,后端直接python写的没使用框架...
ES7+ React/Redux/GraphQL/React-Native snippets 使用指南
VS Code React Snippets 使用指南 目录 简介基础方法React 相关React Native 相关Redux 相关PropTypes 相关控制台相关React 组件相关 简介 ES7 React/Redux/GraphQL/React-Native snippets 是一个用于 VS Code 的代码片段插件,它提供了大量用于 React 开发的代…...
Java中三大构建工具的发展历程(Ant、Maven和Gradle)
🐸 背景 我们要写一个Java程序,一般的步骤是编译,测试,打包。 这个构建的过程,如果文件比较少,我们可以手动使用java, javac,jar命令去做这些事情。但当工程越来越大,文件越来越多,…...
【国产NI替代】32振动/电压(配置复合型)高精度终端采集板卡,应用于复杂的大型测量场景
32振动/电压(配置复合型)高精度终端采集板卡 采用 EP4CE115F29I7 型号的 FPGA ,是一款 高精度,多通道动态信号采集器,主要应用 在复杂的大型测量并对成本要求不敏感的场 合,默认具备 8 个测量板卡&#…...
服务器上加入SFTP------(小白篇 1)
在服务器上配置 SFTP (基于 SSH 的文件传输协议) 通常比传统 FTP 更安全,因为它默认加密通信。以下是详细的配置步骤,以 Ubuntu 或 CentOS 为例。 1.服务器上加入SFTP------(小白篇 1) 2.加入SFTP 用户------(小白篇 2) 3.代码加入SFTP JAVA —&#…...
突围边缘:OpenAI开源实时嵌入式API,AI触角延伸至微观世界
当OpenAI宣布开源其名为openai-realtime-embedded-sdk的实时嵌入式API时,整个科技界都为之震惊。这一举动意味着,曾经遥不可及的强大AI能力,如今可以被嵌入到像ESP32这样的微型控制器中,真正地将AI的触角延伸到了物联网和边缘计算…...
【含开题报告+文档+PPT+源码】基于SpringBoot+Vue的影视网站系统的设计与实现
开题报告 随着互联网的快速发展和普及,人们对于娱乐和信息的需求越来越大。影视网站作为一种提供短视频、影视、电视剧、综艺节目等视频资源的网站,受到了广大用户的喜爱。然而,现有的影视网站系统仍然存在着一些安全性不强,用户…...
前端技术(26) : 全年排班日历
来源: 通义千问 效果图 代码 <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><title>年度日历</title><style>body {font-family: Arial, sans-serif;}.calendar-container {margin: 20px au…...
Linux网络——TCP的运用
系列文章目录 文章目录 系列文章目录一、服务端实现1.1 创建套接字socket1.2 指定网络接口并bind2.3 设置监听状态listen2.4 获取新链接accept2.5 接收数据并处理(服务)2.6 整体代码 二、客户端实现2.1 创建套接字socket2.2 指定网络接口2.3 发起链接con…...
Elasticsearch 数据存储底层机制详解
Elasticsearch 数据存储底层机制详解 Elasticsearch 的底层存储机制依赖 Lucene 来实现数据的组织和管理。下面从数据存储的 流转过程 和 管理机制 两个方面来详细说明。 1. 数据存储流程 当一个文档通过 REST API 被写入 Elasticsearch 时,会经历以下流程&#x…...