- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ORACLE实例的进程结构和内存结构
ORACLE实例的进程结构和内存结构 来源:不详 (2001-05-14 08:28:00) 1.?ORACLE实例的进程结构和内存结构? 1)?进程结构? 进程是操作系统中的一种机制,它可执行一系列的操作步。在有些操作系统中使 用作业(JOB)或任务(TASK)的术语。一个进程通常有它自己的专用存储区。ORACL E进程的体系结构设计使性能最大。? ORACLE实例有两种类型:单进程实例和多进程实例。? 单进程ORACLE(又称单用户ORACLE)是一种数据库系统,一个进程执行全部ORAC LE代码。由于ORACLE部分和客户应用程序不能分别以进程执行,所以ORACLE的代 码和用户的数据库应用是单个进程执行。? 在单进程环境下的ORACLE?实例,仅允许一个用户可存取。例如在MS-DOS上运行O RACLE?。? 多进程ORACLE实例(又称多用户ORACLE)使用多个进程来执行ORACLE的不同部分 ,对于每一个连接的用户都有一个进程。? 在多进程系统中,进程分为两类:用户进程和ORACLE进程。当一用户运行一应用 程序,如PRO*C程序或一个ORACLE工具(如SQL*PLUS),为用户运行的应用建立一 个用户进程。ORACLE进程又分为两类:服务器进程和后台进程。服务器进程用于 处理连接到该实例的用户进程的请求。当应用和ORACELE是在同一台机器上运行, 而不再通过网络,一般将用户进程和它相应的服务器进程组合成单个的进程,可 降低系统开销。然而,当应用和ORACLE运行在不同的机器上时,用户进程经过一 个分离服务器进程与ORACLE通信。它可执行下列任务:? ??对应用所发出的SQL语句进行语法分析和执行。? ??从磁盘(数据文件)中读入必要的数据块到SGA的共享数据库缓冲区( 该块不在缓冲区时)。? ??将结果返回给应用程序处理。? 系统为了使性能最好和协调多个用户,在多进程系统中使用一些附加进程,称为 后台进程。在许多操作系统中,后台进程是在实例启动时自动地建立。一个ORAC LE实例可以有许多后台进程,但它们不是一直存在。后台进程的名字为:? DBWR??数据库写入程序? LGWR?日志写入程序? CKPT?检查点? SMON?系统监控? PMON??进程监控? ARCH?归档? RECO?恢复? LCKn?封锁? Dnnn?调度进程? Snnn?服务器? 每个后台进程与ORACLE数据库的不同部分交互。? 下面对后台进程的功能作简单介绍:? DBWR进程:该进程执行将缓冲区写入数据文件,是负责缓冲存储区管理的一个OR ACLE后台进程。当缓冲区中的一缓冲区被修改,它被标志为“弄脏”,DBWR的主 要任务是将“弄脏”的缓冲区写入磁盘,使缓冲区保持“干净”。由于缓冲存储 区的缓冲区填入数据库或被用户进程弄脏,未用的缓冲区的数目减少。当未用的 缓冲区下降到很少,以致用户进程要从磁盘读入块到内存存储区时无法找到未用 的缓冲区时,DBWR将管理缓冲存储区,使用户进程总可得到未用的缓冲区。? ORACLE采用LRU(LEAST?RECENTLY?USED)算法(最近最少使用算法)保持内存中 的数据块是最近使用的,使I/O最小。在下列情况预示DBWR?要将弄脏的缓冲区写 入磁盘:? ??当一个服务器进程将一缓冲区移入“弄脏”表,该弄脏表达到临界长度 时,该服务进程将通知DBWR进行写。该临界长度是为参数DB-BLOCK-WRITE-BATCH 的值的一半。? ??当一个服务器进程在LRU表中查找DB-BLOCK-MAX-SCAN-CNT缓冲区时,没 有查到未用的缓冲区,它停止查找并通知DBWR进行写。? ??出现超时(每次3秒),DBWR?将通知本身。? ??当出现检查点时,LGWR将通知DBWR? 在前两种情况下,DBWR将弄脏表中的块写入磁盘,每次可写的块数由初始化参数 DB-BLOCK-WRITE-BATCH所指定。如果弄脏表中没有该参数指定块数的缓冲区,DB WR从LUR表中查找另外一个弄脏缓冲区。? 如果DBWR在三秒内未活动,则出现超时。在这种情况下DBWR对LRU表查找指定数目 的缓冲区,将所找到任何弄脏缓冲区写入磁盘。每当出现超时,DBWR查找一个新 的缓冲区组。每次由DBWR查找的缓冲区的数目是为寝化参数DB-BLOCK-WRITE-BAT CH的值的二倍。如果数据库空运转,DBWR最终将全部缓冲区存储区写入磁盘。? 在出现检查点时,LGWR指定一修改缓冲区表必须写入到磁盘。DBWR将指定的缓冲 区写入磁盘。? 在有些平台上,一个实例可有多个DBWR。在这样的实例中,
文档评论(0)