当前位置: 首页 > news >正文

简单理解Oracle中的latch

可以用一个小卖部抢购的例子来理解 Oracle 数据库中的 Latch:


 1、 什么是 Latch?
打个比方,假设数据库的某个内存区域(比如缓存的数据块)是小卖部货架上的最后一包辣条,Latch 就像是货架前的一个狭窄通道:

(1)只能一次过一人:通道非常窄,一次只能一个人通过去拿辣条,其他人必须排队。
(2)动作要快:拿辣条的人动作很急,拿完立刻离开通道(Latch 持有时间极短)。
(3)没有登记名字:如果多人抢,谁会抢到?规则很简单:拼命挤(比如「自旋」重复尝试)或者暂时放弃排队(等待)。
这就是 Latch 的核心作用:保护内存中的关键数据(比如缓存块、链表),避免被多个线程同时修改导致混乱。


 2、关键特点
(1)轻量级:Latch 占资源少,获取和释放极快(像生活中的插队,瞬间完成)。
(2)物理竞争:如果一群人同时抢一个 Latch(比如都想改同一个缓存块),数据库可能卡顿(类似通道堵住)。
(3)自旋 vs 睡眠:
自旋(Spin):线程原地疯狂尝试抢(反复挤通道),适合争抢时间短的情况。
睡眠(Sleep):暂时放弃排队,让出 CPU,适合争抢时间长的情况。


3、Latch 和 Lock(普通锁)的区别
保护对象:
Latch → 内存结构(比如缓存块、链表)。
Lock → 业务数据(比如表中的某一行)。
持续时间:
Latch → 极短(毫秒级)。
Lock → 可能长达事务结束。
管理方式:
Latch → 无队列,简单粗暴抢(挤通道)。
Lock → 有等待队列,公平排队。


 4、举个实际场景
假设多个用户同时修改同一张表的同一行数据:

(1)Oracle 需要先找到这行数据在内存中的位置(缓存块)。
(2)Latch 介入:此时需要短暂获取这个缓存块的 Latch,防止其他线程在读取/修改时出现数据错乱。
(3)Latch 被释放后,才能获取普通的行锁(Lock)继续操作。


5、如果 Latch 争抢严重?
就像一群人挤破头都要抢一个狭窄通道,结果可能是:

数据库性能下降(卡在“挤通道”上)。
通常会看到 latch: cache buffers chains、latch free 等待事件。
解决办法:优化 SQL(减少访问同一数据块)、调整内存参数、分散热点等。



总结:Latch 是 Oracle 内部的高并发“交通指挥员”,用最简单的规则保护内存数据,避免“踩踏事故”。

http://www.lryc.cn/news/543032.html

相关文章:

  • ubuntu新系统使用指南
  • sage-huga改进SITAN
  • DeepSeek开源周Day1:FlashMLA引爆AI推理性能革命!
  • Git add --- error: Filename too long
  • Python入门12:面向对象的三大特征与高级特性详解
  • 动态链接器(九):.init和.init_array
  • Elasticsearch:使用经过训练的 ML 模型理解稀疏向量嵌入
  • 安宝特方案 | 电力行业的“智能之眼”,AR重新定义高效运维!
  • 【落羽的落羽 数据结构篇】树、二叉树
  • [回顾]从原型链视角解读Vue底层实现Vue VueCompoent VM VC关系
  • springcloud nacos 整合seata解决分布式事务
  • 【算法系列】快速排序详解
  • 神经网络发展简史:从感知机到通用智能的进化之路
  • C语言番外篇(4)--------->goto语句
  • AI 编码 2.0 分析、思考与探索实践:从 Cursor Composer 到 AutoDev Sketch
  • Linux与自动化的基础
  • 安全开发-环境选择
  • 【算法设计与分析】(一)介绍算法与复杂度分析
  • SurfaceFlinger代码笔记
  • 2025 PHP授权系统网站源码
  • Fisher散度:从信息几何到机器学习的隐藏利器
  • 深度学习每周学习总结Y1(Yolov5 调用官方权重进行检测 )
  • 实体机器人在gazebo中的映射
  • 【学习笔记】Kubernetes
  • 【网络编程】几个常用命令:ping / netstat / xargs / pidof / watch
  • 上海创智学院(测试)算法笔试(ACM赛制)部分例题
  • 【学术投稿-第四届材料工程与应用力学国际学术会议(ICMEAAE 2025】材料工程与应用力学的探讨
  • 2025吐槽季第一弹---腾讯云EO边缘安全加速平台服务
  • 力扣-动态规划-70 爬楼梯
  • 【DeepSeek】-macOS本地终端部署后运行DeepSeek如何分析图片