全面解析9i以后Oracle Latch闩锁原理

Latch闩锁在Oracle中属于KSLKernelServicesLatching,而从顶层视图来说KSL又属于VOSVirtualOperatingSystem。Latches是一种低级别(low-level)的锁机制,初学IT的

latch闩锁在oracle中属于 ksl kernel services latching, 而从顶层视图来说 ksl又属于vos  virtual operating system。

maclean-latch

Latches 是一种 低级别(low-level)的 锁机制, 初学IT的同学请注意 低级不代表简单, C语言对比java语言要 低级一些但C并不比java简单。

在一些文章著作中也将latch称为spin lock 自旋锁。  latch用来保护 共享内存(SGA)中的数据 以及关键的代码区域。   一般我们说有2种latch:

1)Test and Set 简称TAS  :

TAS是计算机科学中的专指, test-and-set instruction  指令 用以在一个 原子操作(atomic 例如非中断操作)中写入到一个内存位置 ,并返回其旧的值。 常见的是 值1被写入到该内存位置。 如果多个进程访问同一内存位置, 若有一个进程先开始了test-and-set操作,则其他进程直到第一个进程结束TAS才可以开始另一个TAS。

关于TAS指令更多信息 可以参考wiki ,包括TAS的伪代码例子:            

askmaclean.com

在Oracle中Test-And-Set类型的latch使用原生的Test-And-Set指令。 在绝大多数平台上, 零值zero代表latch是 空闲或者可用的 , 而一个非零值代表 latch 正忙或者被持有。  但是仅在HP PA-RISC上 正相反。  TAS latch只有2种状态 : 空闲 或者 忙。

2) Compare-And-Swap 简称 CAS

Compare-And-Swap 也是计算机专有名词, Compare-And-Swap(CAS)是一个用在多线程环境中实现同步的 原子指令( atomic )。 该指令将在一个给定值(given value)和 指定内存位置的内容 之间比对,仅在一致的情况下 修改该内存位置的内容为一个 给定的 新值(不是前面那个值)。  这些行为都包含在一个 单独的原子操作中。 原子性保证了该新的值是基于最新的信息计算获得的; 如果该 内存位置的内容在同时被其他线程修改过,则本次写入失败。 该操作的结果必须说明其到底是否执行了 取代动作。 它要么返回一个 布尔类型的反馈, 要么返回从 指定内存地址读取到的值(而不是要写入的值)。

关于CAS的更多信息可以参考

Oracle中的 Compare-And-Swap Latch也使用原生态的Compare-And-Swap指令。  和TAS Latch类似, 空值代表latch是free的,而一个非空值代表latch正忙。  但是一个CAS latch 可以有多种状态 : 空闲的、 以共享模式被持有 、 以排他模式被持有。 CAS latch可以在同一时间被 多个进程或线程以共享模式持有, 但还是仅有一个进程能以排他模式持有CAS latch。   典型的情况下, 共享持有CAS latch的进程以只读模式访问相关数据, 而一个排他的持有者 目的显然是要写入/修改 对应CAS latch保护的数据。

举例来说, CAS latch的共享持有者是为了扫描一个链表 linked list , 而相反排他的持有者是为了修改这个列表。 共享持有者的总数上线是0x0fffffff即10进制的 268435455。

注意几乎所有平台均支持CAS latch, 仅仅只有HP的PA-RISC平台不支持(惠普真奇葩)。 在PA-RISC上CAS latch实际是采用TAS latch。 所以虽然在HP  PA-RISC上代码仍会尝试以共享模式获得一个latch,但是抱歉最终会以 排他模式获得这个latch。

一般 一个latch会包含以下 信息:

牛面 牛面

牛面AI面试,大厂级面试特训平台

牛面 147 查看详情 牛面

子闩 child latch

当一个单一的latch要保护过多的资源时 会造成许多争用,  在此种场景中 child latch变得很有用。   为了使用child latch,香港服务器,  需要分割原latch保护的资源为多个分区, 最常见的例子是 放入到多个hash buckets里,香港虚拟主机, 并将不同子集的资源分配给一个child latch。 比起每一个hash bucket都去实现一个单独的latch来说, 编程上 使用child latch要方便的多, 虽然这不是我们用户所需要考虑的。  为一个latch 定义多个child latch,则这个latch称为parent latch父闩。  child latch 可以继承 parent latch的一些属性,  这些属性包括 级别和清理程序。  换句话说, child latch就像是parent 父闩的拷贝一样。

经典情况下, 在SGA 初始化过程中child latch将被分配和初始化(startup nomount)。但在目前版本中(10/11g)中也允许在实例启动后 创建和删除latch。

child latch又可以分成2种:

经典情况下, 执行清理函数的进程要么把正在执行过程中的操作回滚掉 ,要么前滚掉。 为了为 前滚(rolling forward)或者回滚(rolling back)提供必要的信息, oracle在latch结构中加入了recovery的结构,其中包含了这个正在执行过程中的操作的日志信息, 这些日志信息必须包含足以前滚或者回滚的数据。  如我们以前讲过的, 理论上oracle进程可能在运行任何指令的时候意外终止,所以清理恢复是常事。

清理恢复最恶心的bug是PMON 执行cleanup function时因为 代码bug ,把PMON自己给弄dead了, 由于PMON的关键的后台进程,所以这会引起实例终止。

Latch和 10.2.0.2后引入的KGX Mutex对比

和 latch一样, kgx mutex也是用来控制串行化访问SGA中数据的 ,但仍有一些重要区别:

Latch 和Enqueue lock队列锁对比,以下是latch和enqueue的几个重大区别:

有同学仍不理解 latch和enqueue的区别的话, 可以这样想一下, latch 保护的SGA中的数据 对用户来说几乎都是不可见的, 例如 cache buffer的hash bucket 对不研究内部原理的用户来说 等于不存在这个玩样,这些东西都是比较简单的数据结构struct ,如果你是开发oracle的人 你会用几百个字节的enqueue 来保护 几个字节的一个变量吗?

而队列锁 TX是针对事务的 , TM是针对 表的,US是针对 undo segment的,这些东西在实例里已经属于比较高级的对象了,也是用户常可见的对象, 维护这些对象 需要考虑 死锁检测、 并发多模式访问、RAC全局锁 等等问题,所以需要用更复杂的enqueue lock。

死锁dead lock

为了使得latch使用足够轻量级 ,死锁预防机制十分简单。  由此Oracle开发人员 在构建一个latch时会定义 一个数字级别 level (从 0 到 16 ), 并且Oracle要求它们必须以level增序顺序获取。  若一个进程/线程在持有一个 latch的情况下,要求一个相同或者更低level的latch的话,KSL层会生成一个内部错误, 这种问题称为 “latch hierarchy violation”。

SQL> select distinct level# from v$latch order by 1;LEVEL#———-01234567891011141516

仅有以nowait模式get latch时可以以级别(level) 非兼容的级别获得一个latch,但是这种情况非常少。

Latch Level 级别

Oracle在定义latch level的时候 取决于以下2个原则:

对于post/wait 类而言 SLEEP_BUCKET和SLEEP_TIME 是被忽略的。

以下是几个latch class:

Class 0  Post/Wait Class ,绝大多数latch都是该类型

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/530231.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月9日 09:59:44
下一篇 2025年11月9日 10:06:28

相关推荐

  • 从Oracle BLOB数据类型在PHP中显示图片:常见问题与解决方案

    本文详细阐述了如何通过php脚本从oracle数据库中获取blob格式的图片数据并正确显示在网页上。核心在于确保php脚本仅输出图片二进制流,避免任何额外的字符或html标签,并正确设置http `content-type` 头。文章将提供示例代码和关键注意事项,帮助开发者避免常见的“图片无法显示”…

    2025年12月12日
    000
  • SQL多表关联更新:使用 EXISTS 优化数据更新策略

    本教程详细阐述了如何在SQL中实现基于多个关联表条件的复杂数据更新。通过一个实际案例,我们展示了如何利用 UPDATE 语句结合 WHERE EXISTS 子句与 INNER JOIN,高效且准确地更新目标表中的数据。文章强调了这种方法的逻辑结构、实现细节及在实际应用中的注意事项,旨在帮助读者掌握高…

    2025年12月12日
    000
  • PHP数据库分页查询实现_PHPLIMITOFFSET分页算法教程

    PHP分页核心是利用SQL的LIMIT和OFFSET控制数据起始位置与数量,通过获取页码和每页条数参数计算OFFSET,结合PDO预处理防止SQL注入,再执行分页查询并生成导航链接;为提升性能,可采用基于ID的游标分页避免深分页扫描、使用覆盖索引减少回表、缓存总记录数降低COUNT开销,并限制最大页…

    2025年12月12日
    000
  • PHP AES-256-CBC 解密函数到 Node.js 的安全移植指南

    本文详细阐述了如何将 PHP 的 AES-256-CBC 解密功能正确移植到 Node.js。通过分析 PHP 原生实现,纠正了 Node.js 移植中常见的 hex2bin 函数误用、密钥和 IV 格式处理不当、以及密文双重 Base64 编码等问题。文章提供了优化的 Node.js 代码示例,并…

    2025年12月12日
    000
  • Windows环境下Laravel项目创建:PHP扩展配置详解与实践

    本文详细介绍了在Windows平台创建Laravel项目时,Composer命令可能遇到的PHP扩展配置问题及其解决方案。通过启用php.ini中的fileinfo和mbstring扩展,可以有效解决因缺少必要扩展导致的项目创建失败,确保Laravel环境的顺利搭建。 1. Laravel项目创建概…

    2025年12月12日
    000
  • PHP数据库加密存储实现_PHP数据加密解密函数详解

    应用层加密结合密钥安全管理可实现数据库敏感数据的高安全性存储,核心是使用AES-256-CBC算法通过openssl_encrypt和openssl_decrypt函数在数据写入前加密、读取时解密,并将随机IV与密文拼接后Base64编码存储;密钥须从环境变量或KMS等安全途径获取,严禁硬编码或提交…

    2025年12月12日
    000
  • PHP数据库触发器实现_PHPTRIGGER定义执行详细教程

    PHP无法直接实现数据库触发器,因为触发器由数据库管理系统在特定事件发生时自动执行。PHP的作用是通过PDO或MySQLi等扩展发送SQL语句来创建、修改或删除触发器,实际逻辑由数据库处理。例如,使用PDO连接数据库后,可执行CREATE TRIGGER语句,在users表插入数据后自动向audit…

    2025年12月12日
    000
  • Linux下SQL*Plus执行SQL语句卡死是什么原因导致的,有哪些解决方法?

    Linux下SQL*Plus执行SQL语句卡死的原因分析及解决方法 在linux系统下使用sql*plus连接数据库后,执行sql语句时出现卡死现象,且没有任何数据返回,即使查询dual表之外的任何表都一样,这个问题困扰着许多数据库管理员。本文将针对此问题进行分析,并提供可能的解决方法。 问题描述:…

    好文分享 2025年12月12日
    000
  • Oracle SQL执行卡住显示“正在执行”怎么办?

    Oracle SQL执行长时间停留在“正在执行”状态,且无结果返回的排查与解决 在执行某些Oracle SQL语句时,可能会遇到长时间显示“正在执行”而无结果返回的情况。例如,以下语句就可能导致此问题: select * from sm_dict_item where sm_grkey =’ccfo…

    2025年12月12日
    000
  • Oracle数据库执行SQL语句卡住“正在执行”状态,如何排查和解决?

    Oracle数据库SQL语句长时间处于“正在执行”状态的排查与解决 在执行select * from SM_DICT_ITEM where sm_grkey =’CCFORM_TSGD_TYPE’ for update 和 update SM_DICT_ITEM set sm_orderno =1 …

    2025年12月12日
    000
  • php特点有哪些

    PHP(超文本预处理器)的特点包括:易用性和可扩展性(语法简单易学,有丰富的函数库和扩展)面向对象编程(支持继承、封装和多态)数据库集成(与主要数据库无缝集成)网站开发(提供交互式网页和处理用户输入的功能)跨平台兼容性(可在各种操作系统和 Web 服务器上运行)开源和免费(开发者可以自由使用、修改和…

    2025年12月12日
    000
  • php实现哪些功能

    PHP是一种通用脚本语言,可用来实现广泛的功能,包括:动态Web开发:生成响应用户请求的动态 веб页面。内容管理系统(CMS):构建允许用户管理网站内容的CMS。电子商务:开发具有购物车、订单处理和支付网关集成的电子商务网站。服务器端编程:编写命令行脚本和工具。文件操作:创建、读取、写入和删除文件…

    2025年12月12日
    000
  • php编程有哪些

    PHP 编程的优势包括:开源且免费跨平台兼容社区支持广泛扩展库丰富与数据库紧密整合动态网页生成模板引擎强大的安全性高性能易于学习 PHP编程有哪些优势? PHP(超文本预处理器)是一种功能强大的服务器端脚本语言,广泛用于Web开发。它具有以下优势: 1. 开源且免费:PHP是一个开源软件,这意味着它…

    2025年12月12日
    000
  • php应用有哪些

    PHP 广泛用于 Web 开发应用,包括:内容管理系统 (CMS):WordPress、Joomla、Drupal电子商务平台:Magento、WooCommerce、PrestaShop博客引擎:WordPress、Ghost、Grav论坛和社区平台:phpBB、Flarum、DiscourseW…

    2025年12月12日
    000
  • php应用包括哪些

    PHP 广泛应用于各种类型应用程序的开发,包括:Web 开发(网站、CMS 和 Web 服务)数据管理(数据库管理和数据分析)命令行工具(脚本自动化和系统管理)移动开发(移动应用程序)其他应用(机器学习、图像处理和分布式系统) PHP 应用范围 PHP 作为一种广泛应用的编程语言,被广泛用于开发各种…

    2025年12月12日
    000
  • php有哪些优势

    PHP 优势包括:易于学习和使用,适合新手开源且免费,无需支付许可费用跨平台支持,可在 Windows、Linux、macOS 和 Unix 上运行拥有庞大生态系统,提供扩展、库和框架支持面向对象编程,增强代码可重用性与流行数据库集成,简化数据操作擅长动态 Web 开发,实现交互性和实时响应性能高,…

    2025年12月12日
    000
  • php有哪些技术

    PHP是一种用于创建动态网页和应用程序的开源服务器端脚本语言。它使用类似于C语言的语法,支持面向对象编程,提供丰富的内置函数库,并可与数据库连接。PHP还支持其他技术,如WebSocket、RESTful API、ORM和模板引擎。它广泛用于开发电子商务网站、社交媒体平台和数据分析仪表板等Web应用…

    2025年12月12日
    000
  • PHP都有哪些优点

    PHP 的主要优点包括:开源且免费跨平台兼容性易于学习活跃的社区支持可扩展性高性能安全功能数据库支持内容管理系统集成面向对象编程 PHP 的优点 PHP 是服务器端脚本语言,因其广泛的用途和易用性而闻名。它提供了众多优点,使它成为开发者中备受欢迎的选择。 1. 开源和免费PHP 是开源和免费的,这使…

    2025年12月12日
    000
  • php都有哪些作用

    PHP(超文本预处理器)是一种服务器端脚本语言,主要用于以下方面:Web 开发:创建动态网站和应用程序服务器端编程:在服务器上执行代码数据库交互:访问和操作关系数据库系统内容管理系统:构建和维护网站内容命令行工具:执行脚本和自动化任务移动应用程序开发:使用混合移动开发框架云计算:与云计算提供商集成 …

    2025年12月12日
    000
  • php有哪些特征

    PHP 是一种开源、跨平台、面向对象的服务器端脚本语言,以其灵活性、易用性和高效性著称。它的主要特征包括:开源且免费,无需支付许可费用。跨平台支持,可在多种操作系统上运行。面向对象,支持类、对象和继承。支持多种数据类型,包括字符串、整数和数组。提供丰富的内置函数,简化开发。支持模块扩展,扩展语言功能…

    2025年12月12日
    000

发表回复

登录后才能评论
关注微信