eygle.com   eygle.com
eygle.com  
 

« 孤独的人是可耻的 | Blog首页 | 参加EMC Forum 2005-加速信息生命周期管理大会 »

在Oracle10gR2中调整过于频繁user commit的一个方法

作者:kamus |【转载时请以超链接形式标明文章和作者信息及本声明
链接:
站内相关文章|Related Articles

我们知道在以往的Oracle版本中,如果commit,那么后台的LGWR进程一定会将内存中的redo数据写入online redo log文件中,然后再将控制权返回给用户(当然,其实这段也可能不是磁盘操作,而是写入到磁盘缓冲中)。如果应用中有过于频繁的用户commit,那么可能会产生明显的log file sync的等待事件。

而Oracle10g中的新功能-Asynchronous Commit可能是解决这个问题的一个新方法(只是看文档自己猜测,并没有真正实践)。

在Oracle10g中我们可以设置commit的行为来做到在commit之后,控制权立刻返回给用户,而Oracle会在恰当的时候唤醒LGWR,批量更新online redo log文件。

我们可以作系统级的更改:
ALTER SYSTEM SET COMMIT_WRITE = BATCH, NOWAIT

同样也可以在commit时单独使用:
COMMIT WRITE BATCH NOWAIT

但是问题在于,这样作的结果,是否意味着即使commit了的事务,在数据库恢复时也是不一定找得回来的。用安全换效率,迫不得已的做法吧。

By kamus on 2005-11-04 04:39 | Comments (0) | Posted to Oracle10g/11g | Edit |Pageviews:

相关文章 随机文章
一场即将到来的费解官司-声援Kamus
10gRAC系列之三-使用crs_stat工具查看资源状态
Linux上iSCSI配置
大佑依然年轻-记罗大佑2005北京演唱会
传华友世纪将收购手机游戏社区当乐网
搜索本站:

留言 (0)

发表留言:



Remember Me?
(输入验证码后方可评论,谢谢支持)



CopyRight © 2004 eygle.com, All rights reserved.