Mysql锁专题:InnoDB锁概述(一)

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: Mysql锁专题:InnoDB锁概述(一)

一 概述



InnoDB与MyISAM有两处不同:


1)InnoDB支持事务;

2)默认采用行级锁(也可以支持表级锁)


对于更新操作(UPDATE、INSERT、DELETE),InnoDB会自动给涉及到的数据集加排他锁(X);对于普通的SELECT语句,InnoDB不加任何锁(所以即使有一个线程的写操作在占用锁,不影响其他线程的读,但是如果某个线程试图加共享锁则不行)。


InnoDB的行锁模式及加锁方法


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


共享锁(S):允许一个事务去读一行,阻止其他事务获得相同数据集的排他锁;

排他锁(X):允许获得排他锁的事务更新数据,阻止其他事务获得相同数据集的共享读锁和排他写锁。


另外,为了允许行锁和表锁共存,InnoDB还有两张内部使用的意向锁,都是表锁:

意向共享锁(IS):事务打算给数据行加行共享锁,事务在给一个数据行加共享锁前先必须取得该表的意向共享锁;


意向排他锁(IX):事务打算给数据行加行排他锁,事务在给一个数据行加排他锁前必须先取得该表的意向排他锁。


上述几种锁的兼容性如下:


表20-6 InnoDB行锁模式兼容性列表


image.png


如果一个事务请求的锁模式与当前的锁兼容,InnoDB就将请求的锁授予该事务;反之,如果两者不兼容,该事务就要等待锁释放。


意向锁是InnoDB自动加的,不需用户干预。


对于更新操作(UPDATE、INSERT、DELETE),InnoDB会自动给涉及到的数据集加排他锁(X);对于普通的SELECT语句,InnoDB不加任何锁(所以即使有一个线程的写操作在占用锁,不影响其他线程的读,但是如果某个线程试图加共享锁则不行)。


显式的给记录集加共享锁:


共享锁: SELECT * FROM tableName WHERE …. LOCK IN SHARE MODE
排他锁: SELECT * FROM tableName WHERE …. FOR UPDATE


二、 共享锁中执行update操作容易导致死锁



注意:**用共享锁然后执行了update操作,则有可能和别的线程的update操作发生锁冲突,从而死锁。死锁后Mysql会自动关闭一个线程的事务操作,让锁被一个线程使用。**如下所示:


1)线程A和线程B对同一行记录使用了共享锁,两个线程读都没有问题(读不需要加锁,不管当前记录加了共享锁还是排他锁,都不影响单独的读操作);


2)线程A进行更新操作,因为更新操作需要加独占锁,而线程B还对当前记录保留了共享锁,故线程A无法获得当前线程的独占锁,要等待线程B释放共享锁;


3)线程B也进行了更新操作,它也要对当前记录加独占锁。那么显然它也无法获得到该记录的独占锁,两个线程都会等待下去,也就是死锁。


4)此时Mysql会自动根据一定规则把锁交给某个线程,另一个线程失去锁重新启动事务。


另外,注意,默认情况下单行执行后就会自动提交事务,此时锁也就被自动释放了。需要关闭事务的自动提交。


set autocommit = 0;


aHR0cDovL3d3dy5waWFuc2hlbi5jb20vaW1hZ2VzLzY1Ny9iZWQzZjU1NDdjOGExYWEwMTM2ZGQ5MWRhMGYyMDE4OS5wbmc.png


对于需要更新的操作,应当直接使用排他锁。这种情况下,因为线程A已经占有了排他锁,线程B无法获得共享锁和排他锁,只能等待。但是注意,InnoDB的读操作不需要加锁,所以可以照常的读。


当使用SELECT…FOR UPDATE加锁后再更新记录,出现如表20-8所示的情况。

表20-8 InnoDB存储引擎的排他锁例子


aHR0cDovL3d3dy5waWFuc2hlbi5jb20vaW1hZ2VzLzk5OC83NTFlZTZmOTVmYTI4ZmZhNWJlNDlhODVmZmNiNmY2Ni5wbmc.png

image.png


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
存储 关系型数据库 MySQL
MySQL InnoDB数据存储结构
MySQL InnoDB数据存储结构
|
1月前
|
存储 缓存 关系型数据库
MySQL的varchar水真的太深了——InnoDB记录存储结构
varchar(M) 能存多少个字符,为什么提示最大16383?innodb怎么知道varchar真正有多长?记录为NULL,innodb如何处理?某个列数据占用的字节数非常多怎么办?影响每行实际可用空间的因素有哪些?本篇围绕innodb默认行格式dynamic来说说原理。
834 6
MySQL的varchar水真的太深了——InnoDB记录存储结构
|
14天前
|
存储 关系型数据库 MySQL
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
31 0
|
12小时前
|
算法 关系型数据库 MySQL
|
1天前
|
SQL 关系型数据库 MySQL
MySQL 锁
MySQL 锁
|
7天前
|
关系型数据库 MySQL 索引
MySQL 锁机制
MySQL 锁机制
7 0
|
14天前
|
关系型数据库 MySQL 数据库
MySQL锁三部曲:临键、间隙与记录的奇妙旅程
MySQL锁三部曲:临键、间隙与记录的奇妙旅程
18 0
|
3月前
|
存储 SQL 关系型数据库
系统设计场景题—MySQL使用InnoDB,通过二级索引查第K大的数,时间复杂度是多少?
系统设计场景题—MySQL使用InnoDB,通过二级索引查第K大的数,时间复杂度是多少?
47 1
系统设计场景题—MySQL使用InnoDB,通过二级索引查第K大的数,时间复杂度是多少?
|
4月前
|
存储 缓存 关系型数据库
⑩⑧【MySQL】InnoDB架构、事务原理、MVCC多版本并发控制
⑩⑧【MySQL】InnoDB架构、事务原理、MVCC多版本并发控制
110 0
|
3月前
|
存储 SQL 关系型数据库
Mysql系列-4.Mysql存储引擎-InnoDB(下)
Mysql系列-4.Mysql存储引擎-InnoDB
46 0