CSDN博主:【java_wxid】
CSDN博主:点击【Java廖志伟】
CSDN社区:点击【幕后大佬】
码云:点击【互联网Java工程师知识扫盲】
随笔 - 882,  文章 - 0,  评论 - 1,  阅读 - 51602

InnoDB是MySQL中常用的存储引擎之一,它支持事务和行级锁,被广泛应用在高并发场景中。行级锁是其核心特性之一,可以保证并发的正确性和性能。

InnoDB的行级锁分为共享锁和排他锁两种,其中共享锁用于读取操作,多个事务可以同时持有共享锁,而排他锁用于更新操作,只有一个事务能获得排他锁。这两种锁可以共存,即读操作可以和读/写操作共存,但是写操作不能和写操作同时存在。

下面将详细介绍InnoDB行锁的实现。

【锁的数据结构】

在InnoDB中,行锁存储在记录锁定信息(Record Lock Information)中,它是一个哈希表,每个哈希项对应一个被锁定的行。这个哈希表在InnoDB的缓冲池中,每个页有一个锁信息页(Record Lock Information Page),它存储在页头信息中。

一个被锁定的行在Record Lock Information中有一个锁信息节点(Record Lock Info Node),锁信息节点包含以下字段:

  • trx_ids:持有锁的事务id。多个事务可以持有共享锁,但只能有一个事务持有排他锁。
  • lock_mode:锁的类型,共享锁(S)或者排他锁(X)。
  • wait_chains:等待链,如果有事务等待这个锁,则它会被加入这个锁信息节点的等待链中。

【锁的获取和释放】

InnoDB采用两阶段锁协议,在事务中,行锁的获取和释放都在事务中完成。

  • 1.锁的获取

当一个事务请求一个行的锁时,InnoDB会先在Record Lock Information中查找这个行的锁信息节点,如果存在,则检查这个锁信息节点中

posted on   我是廖志伟  阅读(102)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

南北踏尘
点击右上角即可分享
微信分享提示