正 文

Oracle:触发Redo写的几个条件


www.7dspace.com  更新日期:2005-11-8 7:45:51  七度空间


  3.提交

  当一个事物提交时,在redo stream中将记录一个提交标志。

  在这些redo被写到磁盘上之前,这个事物是不可恢复的。所以,在事务返回成功标志给用户前,必须等待LGWR写完成。进程通知LGWR写,并且以log file sync事件开始休眠,超时时间为1秒。

  Oracle的隐含参数_wait_for_sync参数可以设置为false避免redo file sync的等待,但是就将无法保证事务的恢复性。

  20:46:02 SQL> @D:\GetHiddenParameter.sql

  Enter value for par: wait_for

  NAME      VALUE ISDEFAULT ISMOD   ISADJ

  -------------- ------- --------- --------- -----

  _wait_for_sync TRUE  TRUE   FALSE  FALSE

  注意,在递归调用(recursive calls)中的提交(比如过程中的提交)不需要同步redo直到需要返回响应给用户。因此递归调用仅需要同步返回给用户调用之前的最后一次Commit操作的RBA。

  存在一个SGA变量用以记录redo线程需要同步的log block number。

  如果多个提交在唤醒LGWR之前发生,此变量记录最高的log block number,在此之前的所有redo都将被写入磁盘。

  这有时候被称为组提交(group commit).

  4.在DBWR写之前

  如果DBWR将要写出的数据的高RBA超过LGWR的on-Disk RBA,DBWR将post LGWR去执行写出。

  在Oracle8i之前,此时DBWR将等待log file sync事件。

  从Oracle8i开始,DBWR把这些Block放入一个defer队列,同时通知LGWR执行redo写出,DBWR可以继续执行无需等待的数据写出。

2页,页码:[1] [2] 

上一篇:对于路由器命令输出的有效过滤
下一篇:看清楚再点 对URL欺骗说不
作者:未知  来源:网络整理 ( 责任编辑:7dspace )
收藏此页】【打印】【关闭
站 内 搜 索
 

热 点 导 读
特 别 推 荐