细化解析:教你轻松掌握Oracle内存结构

来源:岁月联盟 编辑:zhuzhu 时间:2007-09-26

ORACLE在内存存储下列信息:

 ◆执行的程序代码。

 ◆连接的会话信息

 ◆程序执行期间所需数据和共享的信息

 ◆存储在外存储上的缓冲信息。

ORACLE具有下列基本的内存结构:

 ◆软件代码区

 ◆系统全局区,包括数据库缓冲存储区、日志缓冲区和共享池.

 ◆程序全局区,包括栈区和数据区.

 ◆排序区

软件代码区

用于存储正在执行的或可以执行的程序代码。

软件区是只读,可安装成共享或非共享。ORACLE系统程序是可共享的,以致多个ORACLE用户可存取它,而不需要在内存有多个副本。用户程序可以共享也可以不共享。

系统全局区

为一组由ORACLE分配的共享的内存结构,可包含一个数据库实例的数据或控制信息。如果多个用户同时连接到同一实例时,在实例的SGA中数据可为多个用户所共享,所以又称为共享全局区。当实例起动时,SGA的存储自动地被分配;当实例关闭时,该存储被回收。所有连接到多进程数据库实例的全部用户可自动地被分配;当实例关闭时,该存储被回收。所有连接到多进程数据库实例的全部用户可使用其SGA中的信息,但仅仅有几个进程可写入信息。在SGA中存储信息将内存划分成几个区:数据库缓冲存储区、日志缓冲区、共享池、请求和响应队列、数据字典存储区和其它各种信息。

(责任编辑:卢兆林)