视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Oracle关于实例恢复的一个讨论
2020-11-09 07:50:40 责编:小采
文档


问题:在oracle中update一条记录,长时间不提交,DBWn会不会将脏块写入数据文件?LGWR会不会把redo log buffer中的记录写入onlin

问题:在Oracle中update一条记录,长时间不提交,DBWn会不会将脏块写入数据文件?LGWR会不会把redo log buffer中的记录写入online redo log? 如果二者都已写入磁盘,用户发出rollback命令,将会做哪些操作?如果此时数据库实例crash,实例恢复时,将做哪些操作?

讨论结论:

1.当用户DML语句修改一条记录,记录所在脏块是有可能被写入数据文件(提交时间越长,写入数据文件几率越大),,因为DBWn的写触发条件为:每3秒自动唤醒一次;检查点事件;一个服务器进程在规定时间内没有找到空闲块;由上可知,DBWn是否写入,和用户是否提交没有关系;

2.redo log buffer中的记录,也是有可能写入online redo log中,因为LGWR触发条件为:每3秒自动唤醒一次;三分之一满;大小达到1M;commit操作触发;DBWn脏块要写入数据文件中,但是保护该脏块的redo还没写入磁盘,此时会触发LGWR写。由上可知,LGWR的写在未commit的情况下,也可能会写入redo文件。

3.当二者都已写盘,用户发出rollback,则oracle会利用undo块来进行恢复。(undo块也有可能写入磁盘,但是绝对不会被覆盖!)

4.如果此时数据库crash,则oracle会在实例恢复时,先应用redo,进行前滚。前滚完后会进行回滚,将未提交的事务(undo中有记录)进行rollback。

本文永久更新链接地址:

下载本文
显示全文
专题