当我们在共享池中试图分配大片的连续内存失败的时候Oracle首先清除池中当前没使用的所有对象使空闲内存块合并如果仍然没有足够大单个的大块内存满足请求就会产生ORA 错误 当这个错误出现的时候你得到的错误解释信息类似如下: unable to allocate %s bytes of shared memory (\%s\\%s\\%s\\%s\) // *Cause: More shared memory is needed than was allocated in the shared // pool // *Action: If the shared pool is out of memory either use the // dbms_shared_pool package to pin large packages // reduce your use of shared memory or increase the amount of // available shared memory by increasing the value of the // INITORA parameters shared_pool_reserved_size and // shared_pool_size // If the large pool is out of memory increase the INITORA // parameter large_pool_size 共享池相关的实例参数 在继续之前有必要理解下面的实例参数: SHARED_POOL_SIZE 这个参数指定了共享池的大小单位是字节可以接受数字值或者数字后面跟上后缀K 或 M K代表千字节 M代表兆字节 SHARED_POOL_RESERVED_SIZE 指定了为共享池内存保留的用于大的连续请求的共享池空间当共享池碎片强制使 Oracle 查找并释放大块未使用的池来满足当前的请求的时候这个参数和SHARED_POOL_RESERVED_MIN_ALLOC 参数一起可以用来避免性能下降 这个参数理想的值应该大到足以满足任何对保留列表中内存的请求扫描而无需从共享池中刷新对象既然操作系统内存可以限制共享池的大小一般来说你应该设定这个参数为 SHARED_POOL_SIZE 参数的 % 大小 SHARED_POOL_RESERVED_MIN_ALLOC 这个参数的值控制保留内存的分配如果一个足够尺寸的大块内存在共享池空闲列表中没能找到内存就从保留列表中分配一块比这个值大的空间默认的值对于大多数系统来说都足够了如果你加大这个值那么Oracle 服务器将允许从这个保留列表中更少的分配并且将从共享池列表中请求更多的内存这个参数在Oracle i 和更高的版本中是隐藏的提交如下的语句查找这个参数值: SELECT namksppinm NAME valksppstvl VALUE FROM x$ksppi nam x$ksppsv val WHERE namindx = valindx AND namksppinm LIKE %shared% ORDER BY ; g 注释Oracle g 的一个新特性叫做 自动内存管理 允许DBA保留一个共享内存池来分shared poolbuffer cache java pool 和large pool一般来说当数据库需要分配一个大的对象到共享池中并且不能找到连续的可用空间将自动使用其他SGA结构的空闲空间来增加共享池的大小 既然空间分配是Oracle自动管理的ora出错的可能性将大大降低自动内存管理在初始化参数SGA_TARGET大于的时候被激活当前设定可以通过查询v$sga_dynamic_components 视图获得请参考g管理手册以得到更多内容 诊断ORA 错误 注大多数的常见的 ORA 的产生都和 SHARED POOL SIZE 有关这篇文章中的诊断步骤大多都是关于共享池的对于其它方面如Large_pool或是Java_pool内存分配算法都是相似的一般来说都是因为结构不够大造成 ORA 可能是因为 SHARED POOL 不够大或是因为碎片问题导致数据库不能找到足够大的内存块 ORA 错误通常是因为库高速缓沖中或共享池保留空间中的碎片 在加大共享池大小的时 候考虑调整应用使用共享的SQL 并且调整如下的参数 SHARED_POOL_SIZE SHARED_POOL_RESERVED_SIZE SHARED_POOL_RESERVED_MIN_ALLOC 首先判定是否ORA 错误是由共享池保留空间中的库高速缓沖的碎片产生的提交下的查询 SELECT free_space avg_free_sizeused_space avg_used_size request_failures last_failure_size FROM v$shared_pool_reserved; 如果: REQUEST_FAILURES > 并且 LAST_FAILURE_SIZE > SHARED_POOL_RESERVED_MIN_ALLOC 那么ORA 错误就是因为共享池保留空间缺少连续空间所致要解决这个问题可以考虑加大SHARED_POOL_RESERVED_MIN_ALLOC 来降低缓沖进共 享池保留空间的对象数目并增大 SHARED_POOL_RESERVED_SIZE 和 SHARED_POOL_SIZE 来加大共享池保留空间的可用内存 如果 REQUEST_FAILURES > 并且 LAST_FAILURE_SIZE < SHARED_POOL_RESERVED_MIN_ALLOC 或者 REQUEST_FAILURES 等于 并且 LAST_FAILURE_SIZE < SHARED_POOL_RESERVED_MIN_ALLOC 那么是因为在库高速缓沖缺少连续空间导致ORA 错误 第一步应该考虑降低SHARED_POOL_RESERVED_MIN_ALLOC 以放入更多的对象到共享池保留空间中并且加大SHARED_POOL_SIZE 解决ORA 错误 ORACLE BUG Oracle推荐对你的系统打上最新的PatchSet大多数的ORA错误都和BUG 相关可以通过使用这些补丁来避免 下面表中总结和和这个错误相关的最常见的BUG可能的环境和修补这个问题的补丁 |