oracle第8章数据库实例与操作模式

oracle第8章数据库实例与操作模式

ID:40406756

大小:343.01 KB

页数:52页

时间:2019-08-01

oracle第8章数据库实例与操作模式_第1页
oracle第8章数据库实例与操作模式_第2页
oracle第8章数据库实例与操作模式_第3页
oracle第8章数据库实例与操作模式_第4页
oracle第8章数据库实例与操作模式_第5页
资源描述:

《oracle第8章数据库实例与操作模式》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第8章数据库实例与操作模式本章内容Oracle实例Oracle内存结构Oracle后台进程数据库操作模式本章要求掌握Oracle实例基本概念掌握Oracle实例的内存结构、功能及管理了解Oracle进程分类及其作用掌握Oracle后台进程、功能及管理了解Oracle数据库操作模式8.1实例概述Oracle实例的概念是Oracle数据库的软件结构,由一系列后台进程与内存结构组成处理数据的内存结构实例后台进程客户应用程序服务器进程数据库Oracle数据库服务器由数据库和实例组成数据库与实例的关系数据库是Oracle用于保存数据的一系列物理结构和逻辑结构用户直接与实例交互,由实例访问数据库

2、。每个数据库至少有一个与之对应的实例启动数据库时先创建实例Oracle实例组成实例SGA日志缓存共享池数据字典缓冲区库缓冲区DBWRSMONPMONCKPTLGWROthers用户进程服务器进程PGA控制文件数据文件归档日志文件参数文件口令文件重做日志文件数据库数据库缓存8.2Oracle内存结构系统全局区SGASGA区是由Oracle分配的共享内存结构,包含一个数据库实例共享的数据和控制信息。当多个用户同时连接同一个实例时,SGA区数据供多个用户共享,所以SGA区又称为共享全局区。程序全局区PGAPGA区是在用户进程连接数据库,创建一个会话时,由Oracle为用户分配的内存区域,保

3、存当前用户私有的数据和控制信息。8.2.1系统全局区SGASGA包含的内存结构有:数据高速缓冲区(DatabaseBufferCache)共享池(SharedPool)重做日志缓冲区(RedoLogBuffer)其他结构(例如锁管理、统计数据)在SGA,有两个可配置的可选内存结构:大池(LargePool)Java池(JavaPool)数据高速缓冲区功能数据缓冲区存储的是从数据文件中检索出来的数据拷贝。应用程序要访问的数据必须从磁盘的数据文件读到数据缓冲区中处理。在数据缓冲区中被修改后的数据由数据写入进程写到硬盘的数据文件中永久保存。提高获取和更新数据的性能缓冲块的类型:“脏”缓存块

4、(DirtyBuffers)保存的是已经被修改过的数据空闲缓存块(FreeBuffers)不包含任何数据,它们等待后台进程或服务器进程向其中写入数据。命中缓存块(PinnedBuffers)正被使用,或者被显式声明为保留的缓存块缓冲块的管理该列表中包含那些已经被修改但还没有写入数据文件的脏缓存块。LRU列表(LeastRecentlyUsed):该列表中包含所有的空闲缓存块、命中缓存块以及那些还没有来得及移入到脏缓存块列表的脏缓存块。在该列表中,最近被访问的缓存块被移动到该列表的头部,而其他缓存块向列表尾部移动,最近最少被访问的缓存块最先被移出LRU列表,从而保证最频繁使用的数据块始

5、终保存在内存中数据高速缓冲区大小DB_CACHE_SIZE(DB_BLOCK_SIZE、DB_BLOCK_BUFFERS)可以在参数文件中设置数据高速缓冲区的大小。数据高速缓冲区越大,用户需要的数据在内存中的可能性越大,即缓存命中率高,从而减少了Oracle访问硬盘数据的次数,提高数据库系统执行的效率。然而,数据高速缓冲区的值太大,Oracle不得不在内存中寻找更多的块来定位所需要数据,反而降低了系统性能。因此需要确定一个合理的数据高速缓冲区的大小。重做日志缓冲区功能用于缓存在用户对数据进行修改的操作过程中生成的重做记录。当重做日志缓冲区被添满时,由日志写入进程把重做日志缓冲区的内容

6、写到磁盘的重做日志文件中做永久的保存。重做日志缓冲区的大小LOG_BUFFER在参数文件中设置,LOG_BUFFER的值越大,重做日志缓冲区就可以存放更多的事务提交的记录,减少了数据被频繁填充到重做日志文件中的次数。共享池功能用于缓存与SQL或PL/SQL语句、数据字典、资源锁以及其他控制结构相关的数据组成库缓存库缓存用于缓存已经解释并执行过的SQL语句和PL/SQL程序代码,以提高SQL或PL/SQL程序的执行效率。包括SQL工作区和PL/SQL工作区数据字典缓存区数据字典缓存区保存最常用的数据字典信息共享池大小SHARED_POOL_SIZE合适的共享池大小,可使编译过的程序代码

7、长驻内存,大大降低重复执行相同的SQL语句、PL/SQL程序的系统开销,从而提高数据库的性能。大型池功能大型池是一个可选的内存配置项,主要为Oracle多线程服务器、服务器I/O进程、数据库备份与恢复操作、执行具有大量排序操作的SQL语句、执行并行化的数据库操作等需要大量缓存的操作提供内存空间。如果没有在SGA区中创建大型池,上述操作所需要的缓存空间将在共享池或PGA中分配,因而影响共享池或PGA的使用效率。大型池大小大型池的大小由参数LARGE_POOL

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。