细化解析:教你轻松掌握Oracle内存结构
来源:岁月联盟
时间:2007-09-26
ORACLE在内存存储下列信息:
◆执行的程序代码。
◆连接的会话信息
◆程序执行期间所需数据和共享的信息
◆存储在外存储上的缓冲信息。
ORACLE具有下列基本的内存结构:
◆软件代码区
◆系统全局区,包括数据库缓冲存储区、日志缓冲区和共享池.
◆程序全局区,包括栈区和数据区.
◆排序区
软件代码区
用于存储正在执行的或可以执行的程序代码。
软件区是只读,可安装成共享或非共享。ORACLE系统程序是可共享的,以致多个ORACLE用户可存取它,而不需要在内存有多个副本。用户程序可以共享也可以不共享。
系统全局区
为一组由ORACLE分配的共享的内存结构,可包含一个数据库实例的数据或控制信息。如果多个用户同时连接到同一实例时,在实例的SGA中数据可为多个用户所共享,所以又称为共享全局区。当实例起动时,SGA的存储自动地被分配;当实例关闭时,该存储被回收。所有连接到多进程数据库实例的全部用户可自动地被分配;当实例关闭时,该存储被回收。所有连接到多进程数据库实例的全部用户可使用其SGA中的信息,但仅仅有几个进程可写入信息。在SGA中存储信息将内存划分成几个区:数据库缓冲存储区、日志缓冲区、共享池、请求和响应队列、数据字典存储区和其它各种信息。
(责任编辑:卢兆林)