mysql 内存latch_关于MySQL latch争用深入分析与判断

一、latch锁是什么锁

1、定义

latch锁是内存锁,是一个小型的在内存中保护list的内存锁结构。

2、特点

1、不排队

2、spin,一个线程想获得一个锁,但是该锁已被另一线程持有,进行spin(空转随机时间)占用cpu间接性的等待锁的释放,然后获取去进行相关操作。

3、os waits:sleep,spin多次仍然spin

4、cpu繁忙,latch争用

Q:什么是锁?

A:

1、用来保护共享资源,支持并发

2、锁会影响并发

3、latch锁、lock锁

二、latch锁是如何保护list

1、“保护”过程分析

1、访问页先需要访问链

2、修改list不等于修改页

3、什么时候修改list

1、物理读,将数据页挂到list上

2、内存读、修改数据页,修改链

4、锁,其实就是一个内存空间,有结构有数据的内存数据块

s:R共享锁

x:W排它锁

5、锁的兼容性

1、但凡有x锁,排它,就不兼容。

2、latch锁排它就会造成latch争用。

注:mutex互斥锁:针对并发量不是很大的资源。

2、原理图分析

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值