2.阈值达到
只要一个进程在log buffer中分配空间,已经使用的Log buffer的数量将被计算。若是使用的块的
数量大于或等于_log_io_size参数设置,那么将会触发LGWR写操做。
若是此时LGWR未处于活动状态,那么LGWR将被通知去执行后台写操做。
缺省的_log_io_size等于1/3 log buffer大小,上限值为1M,此参数在X$KSPPSV中显示的0值,意为缺省值。
也就是,LGWR将在Min(1M,1/3 log buffer size)时触发。注意此处的log buffer size是以log block来衡量的。
此值一般为512 bytes.
20:33:15 SQL> @D:\GetHiddenParameter.sql
Enter value for par: log_io
old 14: x.ksppinm like '%_&par%'
new 14: x.ksppinm like '%_log_io%'
NAME VALUE ISDEFAULT ISMOD ISADJ
------------------------------ ------------------------- --------- ---------- -----
_log_io_size 0 TRUE FALSE FALSE
Elapsed: 00:00:00.02
|
得到Oracle的隐含参数,参考
如何获取Oracle的隐含参数
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能够继续执行无需等待的数据写出。