作者:順俟自嘫 | 来源:互联网 | 2024-11-14 15:15
假设整个数据库系统每秒提交一次事务,这意味着每秒系统变更号(SCN)增加1。假设初始SCN为1,我们有一个包含10个块的表,每个Oracle块大小为4KB,由8个512字节的操作系统块组成,每行记录占用一个操作系统块。
1. 在数据未修改之前:
每个块由8个操作系统块组成,共有10个块,编号从001到010,每个操作系统块存储一行数据。
2. 修改四个块的四条记录:
如下图所示,有四个UPDATE语句,分别对应RBA(4、9、21、30)。其中,3和4是对block002的修改,它们的检查点队列在同一块中,队列中位置相邻,红色块表示已更新的部分(002第1行,007第2行,001第3行,006第4行)。
3. 重复修改同一块对检查点队列的影响:
block002已被修改两次,但在检查点队列中仍然位于图中的第二个位置。SCN=61是日志文件的RBA或日志文件的地址。例如,执行SQL语句:UPDATE table SET column = value WHERE block = 2 AND row = 3; 当SCN=61时,检查点队列中block002的位置保持不变。
执行ALTER TABLESPACE test BEGIN BACKUP命令后,Oracle会确定检查点SCN。在本例中,检查点SCN确定为68,这意味着在SCN=68时接收到此命令并运行检查点。随后,检查点计数器继续增加,以确保数据文件的版本是最新的,从而避免介质恢复的需要。检查点计数器(checkpoint cnt)记录了检查点执行的次数,最后一次修改的时间以天为单位。
以下是热备份恢复过程的10个步骤原理:
1. 开始热备份:ALTER TABLESPACE test BEGIN BACKUP;
2. 确定检查点SCN:Oracle在接收到BEGIN BACKUP命令时确定检查点SCN。
3. 记录当前数据文件的状态。
4. 复制数据文件到备份介质。
5. 结束热备份:ALTER TABLESPACE test END BACKUP;
6. 归档当前的日志文件。
7. 恢复数据文件:使用备份的数据文件和归档日志文件进行恢复。
8. 应用归档日志文件中的更改。
9. 执行恢复命令:RECOVER TABLESPACE test;
10. 完成恢复:ALTER TABLESPACE test ONLINE;