诊断和解决ORA-04031 错误
Shared Pool的主要问题在根本上只有一个,就是碎片过多带来的性能影响。
1.2.7.1 什么是ORA-04031错误
当尝试在共享池分配大块的连续内存失败(很多时候是由于碎片过多,而并非真是内存不足)时,Oracle首先清除共享池中当前没使用的所有对象,使空闲内存块合并。如果仍然没有足够大的单块内存可以满足需要,就会产生ORA-04031错误。
如下一段伪代码来描述04031错误的产生:
Scan free lists --扫描Free...
分类:
其他好文 时间:
2014-08-02 15:34:23
阅读次数:
317
对于常常要查的结果集,返回少量记录,server端是能够缓存的,结果集保存在共享池中,假设是绑定变量,绑定变量的值也要一样。SQL> show parameter result_cacheNAME TYPE VALUE---------------------...
分类:
数据库 时间:
2014-07-19 11:33:54
阅读次数:
407
今天了解了下Oracle的体系结构整个体系可以用一张图来解释,也可以把他比作一个足球队用户要访问数据库必须通过服务进程去访问数据库里面,最前面是共享池,数据库缓冲区高速缓存和重做日志缓冲区,另外还有java池和大型共享池。共享池里面有库告诉缓存,数据字典高速缓存这些..
分类:
数据库 时间:
2014-07-18 13:02:40
阅读次数:
240
1.keep 让SQL跑得更快。有时候一些基础表需要非常的频繁访问,尤其是在一些循环中,对该表中的访问速度将变的非常重要。为了提高系统的处理性能,可以考虑将一些表及索引读取并保存到内存中。二、关于keep内存的几个参数 下面了解一下具体和CACHE有关的几个概念,即DB_CACHE中的几个pool:...
分类:
其他好文 时间:
2014-07-13 23:25:22
阅读次数:
342
在AWR中定位到问题SQL语句后想要了解该SQL statement的详细运行计划,于是就用AWR报告中得到的SQL ID去V$SQL等几个动态性能视图中查询,但发现V$SQL或V$SQL_PLAN视图都已经找不到相应SQL ID的记录,一般来说这些语句已经从shared pool共享池中被替换出去...
分类:
数据库 时间:
2014-07-11 11:58:50
阅读次数:
307
1.进程结构图对Oracle生产库来讲,服务器进程(可以简单理解是前台进程)的数量远远大于后台进程。因为一个用户进程对应了一个服务器进程。而且后台进程一般出问题几率不大,所以学习重点也是服务器进程和PGA的关系(容易出问题)。2.Oracle 实例管理6大共享池,5大后台进程,3大文件控制文件:记录...
分类:
数据库 时间:
2014-07-03 23:57:51
阅读次数:
406
??
一、ORACLE 物理体系结构
原理结构图
各部分解释:
PGA: 私有内存区,仅供当前发起用户使用。
三个作用
用户登录后的session信息会保存在PGA。
执行排序,如果内存不够,oracle会在临时表空间中完成
保存用户权限信息
SGA: 包含共享池,数据缓冲区,日志缓冲区以及一些相关的进程。
DATABASE:...
分类:
数据库 时间:
2014-06-26 11:51:53
阅读次数:
272
在AWR中定位到问题SQL语句后想要了解该SQL statement的详细运行计划,于是就用AWR报告中得到的SQL ID去V$SQL等几个动态性能视图中查询,但发现V$SQL或V$SQL_PLAN视图都已经找不到相应SQL ID的记录,一般来说这些语句已经从shared pool共享池中被替换出去...
分类:
数据库 时间:
2014-06-18 09:55:27
阅读次数:
332
1调优设计架构设计(RAC/单机)、应用设计(模块设计、E-R模型设计)2调优应用代码调优、应用存储对象调优3条用内存数据高速缓存区、共享池、重做日志缓存区、大池4、调优I/ORAID模式、文件系统与裸设备、存储缓存、表空间数据文件划分、存储对象分布等5、调优竞争回滚段、Lock \Latch
分类:
数据库 时间:
2014-06-17 12:56:20
阅读次数:
293
巴西:战术打法:4222不动摇,主力阵容构架无悬念
核心体系无异议,4222完整诠释,体系架构如此清晰
世界顶级球队:巴西
数据库技术核心团队:甲骨文
教练员:DBA
守门员:归档日志文件
四大后防保证:数据文件、参数文件、日志文件、控制文件
四大中场核心:共享池(库缓存区、数据字典缓冲区)、数据缓冲区、日志缓冲区
双前锋:user进程、server进程
...
分类:
数据库 时间:
2014-06-15 17:49:28
阅读次数:
300