WEB开发网
开发学院数据库Oracle Oracle数据库在线备份原理 阅读

Oracle数据库在线备份原理

 2008-12-16 13:05:51 来源:WEB开发网   
核心提示: 如图所示:把REDO LOG BUFFER保存下来到后台进程是LGWR,LGWR把REDO LOG BUFFER的内容保存到称为REDO LOG FILES中,Oracle数据库在线备份原理(3), REDO LOG FILES 是一组操作系统文件,如图:该数据库中有三组REDO LOG

如图所示:把REDO LOG BUFFER保存下来到后台进程是LGWR,LGWR把REDO LOG BUFFER的内容保存到称为REDO LOG FILES中。 REDO LOG FILES 是一组操作系统文件。如图:

Oracle数据库在线备份原理

该数据库中有三组REDO LOG FILES,每组中有两个成员,这两个成员是相互镜像的。ORACLE 数据库的后台进程写满第一组之后,接着写第二组,写满第二组之后写向第三组。写满地三组之后ORACLE地处处理依据ORACLE运行方式不同而不同。

1.  ORACLE运行方式为非归档方式

在这种情况下,ORACLE数据库不会在任何处理接着写向第一组,将第一组原有的数据覆盖掉。因此REDO LOG FILES原有的数据不可用,故数据库在这种情况下不可恢复。

Oracle数据库在线备份原理

数据库每次写向一组新的REDO LOG FILE 时都会为该组分配一个序号。这个序号是递增,而且唯一的。并且可以按指定的方式REDO LOG FILE的文件名相关。这样如果REDO LOG FILE 在相同的目录下也不会同名。

2.  ORACLE 运行方式为归档方式

在这种情况下,ORACLE数据库接着写向第一组之前,将第一组做一个备份。这个备份就是我们用来做恢复的依据。如图:

Oracle数据库在线备份原理

归档的REDO LOG FILES (ARCHIVED LOG FILE)是对原REDO LOG FILE 的物理拷贝。这个拷贝是可由数据库的后台进程ARCH自动完成的。(由于每一个REDO LOG FILE的名字中有一个唯一的序号,因此ARCHIVED LOG FILE的名字也有一个唯一序号。这个序号决定了做恢复时的使用ARCHIVED LOG FILE 顺序。)

从上可知:

1.  DML语句对数据库的修改记录在REDO LOG BUFFER 中

2.  REDO LOG BUFFER中信息记录在REDO LOG FILE中

3.  REDO LOG FILE 中的信息记录在ARCHIVED LOG FILES 中

因此,把所有的ARCHIVED LOG FILES 保存下来就保存所有对数据库的修改。

用归档来考虑备份与恢复时,必须指出:

1.  如果发出的SQL语句指定了NOLOGGING等将对数据库修改不记入REDOLOGFILE时,这些信息是不能恢复的。此时须借助于其它类型的备份

归档只记录了对数据库的DML语句修改,因此在做恢复时,必须有一个全备份做基础。归档作用在这个全备份上,重演以前对数据库的DML的修改来达到恢复的目的

上一页  1 2 3 

Tags:Oracle 数据库 在线

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接