mysql latch_MySQL中的latch(闩锁)详解——易产生的问题以及原因分析

Latch

什么是latch:

锁是数据库系统区别与文件系统的一个关键特性。锁机制用于管理对共享资源的并发访问。Innodb存储引擎在行级别上对表数据上锁,这固然不错。但是Innodb也会在多个地方使用锁,从而允许多种不同资源提供并发访问。例如,操作缓冲池汇总的LRU列表,删除、添加、移动LRU列表中的元素,为了保证一致性,必须有锁的介入,这就是latch锁。

latch与lock的区别

latch一般称为闩锁(轻量级别的锁),因为其要求锁定的时间必须非常短。若持续的时间长,则应用的性能会非常差。在Innodb存储引擎中,latch又可以分为mutex(互斥量)和RW-Lock(读写锁)。

而lock对象是事务,用来锁定的是数据库中的对象,如表、行、页。并且一般lock的对象仅在事务commit或rollback后进行释放(不同事务隔离级别释放的时间可能不同)。此外,lock,正如在大多数数据库中一样,是有死锁机制的。

mysql latch_MySQL中的latch(闩锁)详解——易产生的问题以及原因分析_第1张图片

同过show engine innodb mutex 进行查看latch

mysql latch_MySQL中的latch(闩锁)详解——易产生的问题以及原因分析_第2张图片

name列显示的是latch的信息以及源码所在的位置(行

你可能感兴趣的:(mysql,latch)