正 文

Oracle:触发Redo写的几个条件


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


  主要有以下几个条件触发LGWR执行写操作:

  1.超时(timeout)

  当LGWR处于空闲状态时,它依赖于rdbms ipc message等待,处于休眠状态,直到3秒超时时间到。

  如果LGWR发现有redo需要写出,那么LGWR将执行写出操作,log file parallel write等待事件将会出现。

  启用10046事件,从LGWR跟踪日志中可以清楚的观察到这些事件:

  WAIT #0: nam='rdbms ipc message' ela= 2999554 p1=300 p2=0 p3=0

  WAIT #0: nam='rdbms ipc message' ela= 2999470 p1=300 p2=0 p3=0

  WAIT #0: nam='rdbms ipc message' ela= 566819 p1=300 p2=0 p3=0

  WAIT #0: nam='log file parallel write' ela= 115 p1=1 p2=2 p3=1

  WAIT #0: nam='rdbms ipc message' ela= 45752 p1=213 p2=0 p3=0

  WAIT #0: nam='log file parallel write' ela= 94 p1=1 p2=3 p3=1

  WAIT #0: nam='rdbms ipc message' ela= 51762 p1=208 p2=0 p3=0

  WAIT #0: nam='log file parallel write' ela= 91 p1=1 p2=1 p3=1

  WAIT #0: nam='rdbms ipc message' ela= 29033 p1=200 p2=0 p3=0

  WAIT #0: nam='log file parallel write' ela= 99 p1=1 p2=2 p3=1

  WAIT #0: nam='rdbms ipc message' ela= 40293 p1=197 p2=0 p3=0

  WAIT #0: nam='log file parallel write' ela= 87 p1=1 p2=1 p3=1

  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的隐含参数

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

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

热 点 导 读
特 别 推 荐