异步提交oracle,oracle 10g数据库的异步提交

Oracle10gR2新特性:Asynchronous COMMIT

对于Oracle的commit机制,相信大家都已经非常的熟悉了。Oracle对于commit采取了同步写事务log的方式,也就是说,一旦发出commit命令,那么必须等待事务相关的所有redo都已经从

log buffer写出到redo logfile以后,才会控制权返回发出commit的进程。

同步commit有两个特点:

1.Immediate,发出commit命令后,立即将redo写出

2.Wait,在redo写出过程中,必须等待

但是,Oracle10gR2开始,一种新的commit机制被引入,这就是异步commit机制。也就是说,不必等到事务相关redo写出就可以返回了,异步commit也有两种特点:

1.Nowait,发出commit命令后,不关redo是否写出,立即返回控制权

2.Batch,redo的写出可以想buffer一样执行批量写出,以提高性能

当然,同步commit也可以batch,异步commit也可以将redo立即写出,所以上述四个特性可以自由组合。

这样,commit引入了新的语法:

COMMIT [WRITE [IMMEDIATE | BATCH] [WAIT | NOWAIT] ]

默认情况下,commit的机制和以前一样,也就是相当于

COMMIT WRITE IMMEDIATE WAIT;

当然,这个默认机制可以通过初始化参数修改,所以Oracle10gR2又引入了一个新的参数COMMIT_WRITE,可能的取值包括

COMMIT_WRITE='{ IMMEDIATE | BATCH } , { WAIT | NOWAIT }'

异步commit由于不能确保事务的redo已经写出到redo

logfile当中,一旦实例崩溃,可能导致已经commit的事务无法恢复,使用该特性的时候需要慎重考虑。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值