Shared pool和library cache latch
这篇技术文章聚焦于Oracle数据库中一个关键却常被忽略的底层机制:Shared pool latch。作者从其核心作用切入——它主要负责保护共享池的内部结构,在内存分配、释放乃至老化处理时都需要被获取,是维护共享池稳定性的关键“门锁”。 文章清晰地梳理了一个重要的技术演进。在Oracle 9i版本之前,整个共享池由单一的Shared pool latch统一保护。而自9i开始,Oracle引入了多子池(sub pool)设计:当服务器CPU核心数超过4个,且`shared_pool_size`设置大于250MB时,共享池会被动态划分为多个子池(最多7个),每个子池拥有独立的内存结构、LRU列表以及自己的latch。这意味着对共享池的操作竞争,从单一的“瓶颈”被分散到了多个子池的latch上,从而提升了在高并发环境下的性能。 此外,文章也指出了人工干预的可能性,管理员可以通过`_kghdsidx_count`参数来手动设定子池的数量,为性能调优提供了一个更精细的调控点。对于理解Oracle内存管理机制和进行性能诊断的DBA来说,厘清这一 latch 的作用与演变历史,是诊断共享池竞争问题的重要基础。