简单理解Oracle中的latch

news/2025/2/26 18:10:03

可以用一个小卖部抢购的例子来理解 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.niftyadmin.cn/n/5869039.html

相关文章

【docker】namespace底层机制

Linux 的 Namespace 机制是实现容器化(如 Docker、LXC 等)的核心技术之一,它通过隔离系统资源(如进程、网络、文件系统等)为进程提供独立的运行环境。其底层机制涉及内核数据结构、系统调用和进程管理。以下是其核心实…

angular新闻列表分页

说明:使用angular技术,material控件,ngfor循环,img网络图片展示,分页组件 效果图: step1: C:\Users\Administrator\WebstormProjects\untitled4\src\app\home\home.component.ts import { Component, V…

解决安卓recyclerView滚到底部不彻底问题

问题分析: 传统recycleview滚到到底部方式scrollToPosition(lastpositon),只能定位到最后一条数据的顶部。由于数据过长,无法滚动到最底部。 问了下deepseek,给了个方案: private void recyclerViewScrollToBottom()…

Qt/C++项目积累:3.日志管理系统 - 3.1 项目介绍

在实际工程项目中,日志系统无疑是比较重要地分析问题的手段,常用的一般是将其写入到日志文件中,或者写入数据库文件,进行分析,而工程人员或者开发人员需要实时查看日志,可能不太方便,于是就需要…

DeepSeek 助力 Vue 开发:打造丝滑的分割线(Divider)

前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 目录 Deep…

《Vue全栈图形绘制系统开发实战》—— 第一章础架构与核心模块实现

第一章 基础架构与核心模块实现 #mermaid-svg-am3qjLePI9PBjAJy {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-am3qjLePI9PBjAJy .error-icon{fill:#552222;}#mermaid-svg-am3qjLePI9PBjAJy .error-text{fill:#552…

浅析DeepSeek在商业银行的应用

在金融科技蓬勃发展的时代背景下,人工智能技术正重塑商业银行的运营模式与服务生态。DeepSeek作为一款极具潜力的大语言模型,可凭借其独特的优势广泛应用于商业银行多个业务领域,为银行数字化转型注入新动力。然而,与所有新兴技术类似,DeepSeek在应用过程中也面临诸多挑战…

数据结构实战:高效的缓存系统(哈希表 + LRU算法)与分布式任务调度系统(树形结构 + 图形算法)

系列文章目录 01-从零开始掌握Python数据结构:提升代码效率的必备技能! 02-算法复杂度全解析:时间与空间复杂度优化秘籍 03-线性数据结构解密:数组的定义、操作与实际应用 04-深入浅出链表:Python实现与应用全面解析 …