ORA-04031错误分析和解决

简介: ORA-04031错误分析和解决 查询v$shared_pool_reserved视图可以判断共享池问题的引发原因: SQL>select FREE_SPACE,AVG_FREE_S...

ORA-04031错误分析和解决 

查询v$shared_pool_reserved视图可以判断共享池问题的引发原因:

 


SQL>select FREE_SPACE,AVG_FREE_SIZE,USED_SPACE,AVG_USED_SIZE,REQUEST_FAILURES,LAST_FAILURE_SIZE from v$shared_pool_reserved;

 

FREE_SPACE AVG_FREE_SIZE USED_SPACE AVG_USED_SIZE REQUEST_FAILURES LAST_FAILURE_SIZE

---------- ------------- ---------- ------------- ---------------- -----------------

2685760 167860 0 0 0 0

 

如果request_failures>0LAST_FAILURE_SIZE>shared_pool_reserved_min_alloc,那么4031可能是因为共享池包括空间缺少连续的空间所致;考虑加大shared_pool_reserved_min_alloc,并增大shared_pool_reserved_sizeshared_pool_size来加大共享池保留空间的可用内存。

如果request_failures>0LAST_FAILURE_SIZE<shared_pool_reserved_min_alloc,或者request_failures=0LAST_FAILURE_SIZE<shared_pool_reserved_min_alloc,那么应考虑降低shared_pool_reserved_min_alloc

 

shared_pool_reserved_min_alloc参数值的查询:

SQL>

column name format a35

column value format 9999999

column ISDEFAULT format a5

column ISMOD format a5

column ISADJ format a5

select

x.ksppinm name,

y.ksppstvl value,

y.ksppstdf isdefault,

decode(bitand(y.ksppstvf,7),1,'modified',4,'system_mod','false') ismod,

decode(bitand(y.ksppstvf,2),2,'true','false') isadj

from

sys.x$ksppi x,

sys.x$ksppcv y

where

x.inst_id = userenv('instance') and

y.inst_id = userenv('instance') and

x.indx = y.indx

and x.ksppinm like '_shared_pool%' ---/**_% 查询所有隐含参数

/

NAME VALUE ISDEF ISMOD ISADJ

----------------------------------- ------- ----- ----- ---------------------------------------------------

_shared_pool_reserved_pct 5 TRUE false false

_shared_pool_reserved_min_alloc 4400 TRUE false false

经验谈:

设置 _shared_pool_reserved_min_alloc=4100 ,不建议设置更低;一般在 4100~4400 之间。

 

相关文章
|
SQL 关系型数据库 MySQL
ORA-01948和ORA-04052错误的解决方法
一、事件背景: 业务人员在创建一个物化视图的时候,报了以下错误: SQL> CREATE MATERIALIZED VIEW MV_RETAIL_wbmout_R 2 TABLESPACE SAPDATA 3 PCTUSED 0 ...
1729 0
|
缓存 Oracle 关系型数据库
重现ORA-01555错误
非常经典的一个一致性快照过旧的错误,Oracle面试必读。
|
Oracle 关系型数据库
ORA-00060错误
今天有个同事说生产机有个PERL脚本老是报死锁的错误,脚本里面开启了并行度:错误如下: Failure: ORA-12801: error signaled in parallel query server P126, instance NMS_ODS_NDB1:wgods1 (1)ORA-000...
1278 0
|
SQL 关系型数据库 Oracle
ORA-00911错误
ORA-00911,"911"看着很霸气的错误号,虽然我还是Oracle的初学者,但每次碰到一个未见过的ORA错误号后,都有一种查案的赶脚,根据错误号、OERR、相关错误信息,判断错误原因以及找到解决方案或替代方案,虽然大部分可能还是参考前辈或官方,但碰到一次后,至少是似曾相识了,再次碰到时即使不记得,大概也能有个方向。
1061 0
|
Oracle 关系型数据库 数据库
|
索引 数据库管理