网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.oracle imp字符集问题的解决.
.docmd.runsql 语句执行的操作查询.
.入侵oracle数据库时常用的操作命.
.如何释放过度占用的Shrink Undo表.
.10g不支持的Linux发行版上安装10.
.Lock_sga = true 的问题.
.Oracle的入门心得.
.sendmail支持的操作系统有哪些.
.Oracle9i 数据库管理实务讲座(二.
.用VC 开发基于ORACLE数据库应用程.
.MySQL5、PostgreSQL8和Oracle10g.
.Oracle数据库最优化参数缩短反应.
.遇到ora-12535问题后应当采用哪些.
.创建catalog 数据库步骤.
.如何使用归档日志进行完全恢复.
.查询session被锁的sql.
.ORACLE 培训教程(1).
.Oracle10g对回滚操作时间的准确评.
.教你快速掌握如何使用"Opatch"打.
.直接挖掘数据文件的数据.

oracle-触发redo写的几个条件

发表日期:2008-2-9



  主要有以下几个条件触发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的隐含参数
  
  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可以继续执行无需等待的数据写出。
上一篇:项目中的oracle开发技巧 人气:515
下一篇:oracle数据库java接口类 人气:700
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐