Oracle进程和相关示意图.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
oracle后台进程 1,处理用户请求,同时维护数据库系统使其始终具有良好的性能。 2,从用户进程处接受到任务,然后进行I/O操作、监视各个进程的状态、维护系统的性能和可靠性 9i中主要的后台进程 数据库写进程(DBWRn) 将脏缓存块写入数据文件 日志写进程(LGWR) 将重做日志缓存区的重做记录写入联机重做日志 检查点进程(CKPT) 调用DBWR或LGWR将所有脏缓存块写入数据文件,已实现数据库完整性 系统监视进程(SMON) 在实例启动时负责恢复数据库,回收表空间空闲空间 进程监视进程(PMON) 恢复那些失败的进程,并释放其进程所占系统资源。定期检查调度程序和服务进程 归档进程(ARCn) 将已经写满的重做日志文件复制到归档目标中 恢复进程(RECO) 分布式数据库环境中自动恢复那些失败的分布式事务 调度程序进程(Dnnn) 接受用户进程的请求,将他们放入请求队列中,然后为请求队列中的用户进程分配一个服务进程。 注意:oracle还有一些可选后台进程。比如,在使用作业队列功能(oracle job queue) 时将会启动作业队列进程CJQn;在使用高级队列功能(oracle advanced queue)时将启动队列监视进程QMNn。这些进程不会对实例的运行造成太大影响,即使失败也不会导致实例崩溃。 数据库写进程(DBWRn) 将脏缓存块写入数据文件 DBWR不是将所有的脏缓存块写入数据文件,因为脏缓存块一旦被写入数据文件,它将被标记为空闲缓存块,其中保存的数据将丢失。如果随后立即有其他的用户进程来访问缓存块中以前所保存的数据,oracle需要重新到数据文件中读取。 这样很显然不是我们所期望的 通过LRU算法能够解决这个问题。LRU(最近最少使用)算法。 最近未被访问过的缓存块被标记为“冷缓存块(cold cache block)”,DBWR进程只将那些同时被标记为“脏”和“冷”的缓存块写入数据文件, 这样,那些经常被访问的脏缓存块将继续保留在缓存中,直到他们不再需要使用时才由DBWR进程写入数据文件。 脏缓存块:如果某个缓存块的数据被修改,它将被标记为脏 DBWR的数量DBW1~DBW9 。DBWR进程的数目不应该超过系统CPU的数目,因为每个处理器同时只能运行一个DBWR进程。 将脏缓存块写入数据文件的情况 1,空闲缓存块不够时, dbwr将脏缓存块写入数据文件! 2,当检查点发生时,启动dbwr 3,当数据库缓存的LRU列表的长度达到初始化DB_BLOCK_WRITE_BATCH 指定值的一半时,dbwr将被启动 4,若发生超时(大约3秒内未被启动),DBWR进程将被启动 注意:DBWR进程启动的时间与用户提交事务的时间完全无关。也就是说,在执行commit语句提交事务之后,与该事务相关的脏缓存块并不是立即写入数据文件中的(但是执行commit语句后将立即启动LGWR将事务写入重做日志文件)。 DBWR的启动时间太长,对将来恢复数据库不利,启动时间太短,将给系统I/O带来很多的负担。 与DBWR相关的初始化参数 DB_WRITER_PROCESSES 这个参数用于设置创建实例时启动的DBWR后台进程数量,默认为1,即在创建实例时仅启动一个DBWR(DBW0) DB_BLOCK_CHECKPOINT_BATCH 这个参数用于设置在每个检查点发生时,DBWR进程写入的脏缓存块的最大数目。增大该参数,可以延长启动DBWR进程的时间间隔。 DB_BLOCK_LRU_LATCHES 设置数据库缓存区中LRU闩的数量。 闩(Latch):oracle用于顺序访问内部系统结构的锁;它被用来控制数据库缓存写入操作的争用。 多处理器系统中,这个参数值通常是处理器数目的一半。 LGWR(日志写进程) 日志写进程负责将重做 缓存中的重做记录写入联机重做日志文件。缓存中的数据写入重做日志文件之后,相应的缓存内容将被清空。 1,下列情况下,oracle将缓存中的数据写入重做日志文件。 ·用户通过COMMIT语句提交当前事务 ·重做日志缓存被写满三分之一 ·DBWR进程开始将脏缓存块写入数据文件 ·每隔3秒,即发生一次超时,此时会启动LGWR 事务修改了数据库==》将在数据库缓存中产生脏缓存块,同时在重做日志缓存中产生重做记录。。 如果DBWR进程要将事务的结果写入数据文件,但发现与要写入的脏缓存块相关的重做信息仍然处于重做日志缓存中,它将通知oracle启动LGWR进程,先将这些重做信息写入重做日志文件,直到重做信息全部被写入后,DBWR进程才开始将脏缓存块写入数据文件。 这样做保证了数据库的完整性。将来可以做完全恢复或者回退该事务! 如果创建了复合日志文

文档评论(0)

kehan123 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档