Mysql间隙锁死锁避免最佳实践

最近写代码的时候听说,批量操作提高死锁的概率,但是心里又想,为什么没看到任何一款数据库相关的中间价禁止或者提醒批量操作?心里想肯定是因为一起其他操作的不当导致的死锁问题。进行了一些思考,希望可以帮助到大家

Mysql死锁的根本原因

死锁诞生的四个必要条件,这个是理论的基础,这个就不讲了,看下最常见也是开发中最容易导致的死锁问题。

很多大厂为了提高性能,会把RR隔离级别改为RC隔离级别,取消了间隙锁,提高性能的同时也大大避免了死锁的概率。

而RR相比RC隔离级别,主要就是间隙锁这个玩意儿,解决当前读时(每次获取最新的数据,而不是快照)的幻读问题,当然并没有完全解决,这个自己去探究,和本文关系不大。

1.为什么说高并发大厂改为RC隔离级别,速度就提高了,死锁概率也大大降低了?

2.对于大多数公司,并没有极高的并发,就是采用RR隔离级别,应该怎么做,才能减少因间隙锁导致的死锁问题呢?

到这里就有答案了:大多数mysql遇到的死锁都是因为RR隔离级别,需要通过间隙锁,解决幻读问题,开发人员又没充分的理解间隙锁何时会加,怎么避免不必要的加间隙锁,而导致的死锁问题;

Mysql何时会加间隙锁?

想要避免因间隙锁死锁导致的问题,首先,要弄清究竟什么时候会加间隙锁?

对于delete 、 update、select xxx for update带有加锁性质的语句,会加间隙锁。至于怎么加?为什么加间隙锁就死锁了,听我慢慢讲。

1.如果这些语句没走索引,网上我看很多文章都说,不走索引,就会加表锁。。。这纯属于瞎扯。

这是因为加next-lock临键锁,没走索引,发生了全表扫描,整个表都加上了锁,整个表的间隙都加上了间隙锁,也就是整个表加了临键锁(间隙锁+记录锁)

2.如果走了索引:会因为这个情况加锁,而且死锁:(这是通用的间隙锁死锁原因):

间隙锁是并不是互斥的,事务1给一段范围加了间隙锁,事务2也可以给这段范围加间隙锁,互斥的是插入意向锁和间隙锁互斥,正常来说就是:事务1加了间隙锁,事务2插入的时候会生成一个插入意向锁,这样就避免了幻读问题。

不正常的时候就是事务1加了间隙锁,事务2在同样的范围也加了间隙锁,进行操作的时候,两个事务就会死锁了,比如事务1插入,被事务2的间隙锁阻塞,事务2插入,被事务1的间隙锁插入。

死锁例子:事务1执行加了间隙锁       

                                                        事务2执行加了间隙锁

                事务1插入记录(阻塞)

                                                         事务2插入记录(阻塞)   死锁发生了。

这样的例子很多。

比如:

(1) 表的数据有 1。 2   3。

        事务1,删除4,加临键锁(3,正无穷]       

                                                                        事务2,删除5,加临键锁(3,正无穷]

        事务1。insert。  4(阻塞)

                                                                        事务1。insert。  4(阻塞)

(2) 加锁读:1,2,3

        事务1。select 4 for update      加临键锁(3,正无穷] 
                                                                             事务2,  select 5 for update  加临键锁(3,正无穷] 

        事务1。insert。  4(阻塞)                                   事务1。insert。  4(阻塞)

(3)更新同上

(4)(5)(6)

这里只是间隙锁死锁,insert可以换成是其他操作,delete。update可以探究下是否会阻塞死锁。

大致的加锁就是这样。

可以看到上面的例子,大多是对于不存在的操作进行改变,不存在,就一定会加间隙锁。

如何避免间隙锁死锁?

暴力就是有大厂类似需求的,不用RR,就不会有间隙锁死锁。(不推荐,大多数公司用不了)

通过上面的分析:

避免死锁死锁有这些最佳实践

1.删除、更新之前,先判断在不在,不在的数据,进行删除更新,虽然不会报错(返回0rows)但是。操作一定会加间隙锁。开发人员要避免这种情况

2.尽量通过主键操作,先查出主键,再进行删、改操作,就只会加行锁,不会加间隙锁

3.一定要保证这些加锁的语句走了索引,不走索引的话,会导致整个表加锁,整个表的间隙也加锁,是很多next-lock锁,而不是表锁!

4.仅仅真的涉及幻读问题的时候,才让间隙锁去发挥他的作用,比如selet for update,语句需要的时候,大多数场景用不到间隙锁,就开发的时候避免掉这些间隙锁,也就是尽量遵循上面1 2 3逻辑。

还有就是尽量少量批量了,上面4条降低死锁,这一条就尽量让事务快速的执行完,减少多个事务并发,持有相同的间隙锁。

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

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

相关文章

WebGL画粗线

目录 前言 基本思路 求左右端点 实现 组织数据 顶点着色器计算端点坐标 效果 前言 WebGL绘制模式有点、线、面三种;通过点的绘制可以实现粒子系统等,通过线可以绘制一些连线关系;面就强大了,通过面,我们可以…

视频监控汇聚平台LntonCVS国标GB28181协议实现语音对讲功能

在当今这个智能技术飞速发展的时代,人工智能已经成为了电子产品领域的一股不可忽视的热门趋势。随着科技的不断进步,越来越多的电子产品开始融入人工智能技术,从而为其开拓了全新的发展路径。在这个大背景下,安防摄像头无插件直播…

什么叫硬编码?如何避免硬编码

硬编码(Hardcoding或Hard-coding)是指在编写程序时,直接将具体的值(如字符串、数字、路径等)写入源代码中,而不是通过变量、配置文件、数据库查询或其他动态方法来获取这些值。这种方式虽然简单直接&#x…

基于springboot实现智慧校园之家长子系统项目【项目源码】计算机毕业设计

基于springboot实现智慧校园之家长子系统演示 SpringBoot框架介绍 本课题程序开发使用到的框架技术,英文名称缩写是SpringBoot,在JavaWeb开发中使用的流行框架有SSH、SpringBoot、SpringMVC等,作为一个课题程序采用SSH框架也可以&#xff0c…

microsoft office从c盘移动到d盘之后被损坏

千万不能移动!移动之后不管在D盘还是移回C盘都不能用了 解决办法: 打开控制面板的卸载程序,点击microsoft office的更改,再点击联机恢复就可以了

【学习】测试用例设计与执行的黄金法则

在软件测试领域,测试用例的设计与执行是确保产品质量的关键环节。一个优秀的测试用例能够揭示软件中的缺陷,而高效的执行则能保障测试覆盖的全面性。如同璀璨的星辰指引航船前行,以下黄金法则将引领测试用例设计与执行的过程,确保…

企业数据确权与数据知识产权的讨论

什么是数据知识产权? 数据知识产权是权利人对经过一定算法加工、具有实用价值和智力成果属性的数据,依法享有的专有权利,并指出进行交易的数据知识产权需要明确权属关系,以保证数据知识产权能够依法出让。 数据知识产权与数据资产…

Go 群发邮件Redis 实现邮件群发

一、安装 go get github.com/go-redis/redis/v8 go get gopkg.in/gomail.v2 二、使用"gopkg.in/gomail.v2"群发 package mainimport (gomail "gopkg.in/gomail.v2" )func main() {// 邮件内容m : gomail.NewMessage()m.SetHeader("From", &qu…

【杂谈】AIGC之Stable Diffusion:AI绘画的魔法

Stable Diffusion:AI绘画的魔法 引言 在AI的世界里,Stable Diffusion就像一位魔法师,它能够将我们脑海中的幻想,用画笔一一描绘出来。今天,就让我们一探这位魔法师的奥秘,看看它是如何从无到有&#xff0…

3.00002 postgresql如何初始化内存上下文,都初始化了哪些上下文?

文章目录 解决问题:PostgreSQL 7. 1 以前的版本在处理大量以指针传值的查询时一直存在着内存泄漏的问题,直到 查询结束才能将内存收回 。内存上下文-数据结构内存上下文-启动相关函数MemoryContextInitAllocSetContextCreate (宏,定义为:AllocSetContextCreateInternal (as…

Human Guided Ground-truth Generation for Realistic Image Super-resolution

香港理工大学&OPPO&哈工大 CVPR2023https://github.com/ChrisDud0257/HGGT 问题引入 现在通过模拟退化过程来从高分辨率图像生成低分辨率图像,但是该过程没有引入人类的感知;所以本文首先训练了多个超分模型,为一张LR生成多张对应的…

安装MongoDB单副本说明

参考:https://blog.csdn.net/weixin_43464076/article/details/126509254 https://driverzhang.github.io/post/mongo%E5%BC%80%E5%90%AF%E4%BA%8B%E5%8A%A1%E4%B9%8B%E5%89%AF%E6%9C%AC%E9%9B%86%E9%87%87%E5%9D%91/ https://dev.to/alexalvess/getting-started-wi…

【Javascript系统学习】

语法与数据类型 语法 var\let\const var 声明一个变量,可选初始化一个值。 let 声明一个块作用域的局部变量,可选初始化一个值。 const 声明一个块作用域的只读常量。 用 var 或 let 语句声明的变量,如果没有赋初始值,则其值为 …

实习面试题(答案自敲)、

1、为什么要重写equals方法,为什么重写了equals方法后,就必须重写hashcode方法,为什么要有hashcode方法,你能介绍一下hashcode方法吗? equals方法默认是比较内存地址;为了实现内容比较,我们需要…

mysql表级锁(表锁/元数据锁/意向锁)

文章目录 表级锁的分类1、表锁(分类)1.表共享读锁(read lock)2.表独占写锁(write lock)3.语法: 2、元数据锁(meta data lock )3、意向锁1.意向共享锁(IS):由语…

【wiki知识库】05.分类管理实现--前端Vue模块

📝个人主页:哈__ 期待您的关注 目录 一、🔥今日目标 二、🌏前端部分的改造 2.1 新增一个tool.ts 2.2 新增admin-categoty.vue 2.3 添加新的路由规则 2.4 添加the-welcome.vue 2.5 修改HomeView.vue 三、❗注意 一、&…

车来了冲刺上市:业绩波动明显,依赖广告业务,滴滴、阿里入股

近日,MetaLight Inc.(下称“元光科技”或“车来了”)向港交所递交招股说明书,中金公司为其独家保荐人。 据招股书介绍,元光科技专注于利用时序数据(按时间顺序排列的数据点)来发现及预测分析对…

用队列实现栈-力扣

本题是使用队列来实现栈,在栈实现队列时,我们使用了输入栈和输出栈来调整输出顺序,但时队列不同,队列元素先入先出,即使使用两个队列,也没法调整到先入后出。因此做法是依次将队列元素出队,然后…

docker 存储 网络 命令

文章目录 1 docker存储1.1 目录挂载2.1卷映射2.1.1卷映射和目录挂载的区别2.1.2卷映射的使用 2 docker网络2.1查看docker的默认网络2.2查看容器的IP2.3容器互通2.4自定义网络2.4.1 创建自定义网络2.4.2创建容器的时候加入到自定义的网络2.4.3使用域名进行容器之间的访问2.4.4re…

盛凌电子IPO终止:实控人蒋志坚曾和前妻黄新打官司,儿子已离职

保荐人撤销,致使公司IPO终止。 近日,深圳证券交易所披露的信息显示,深圳盛凌电子股份有限公司(下称“盛凌电子”)的保荐人申万宏源证券撤回上市申请文件。因此,深圳证券交易所决定终止对该公司首次公开发行…