Rman 一个强大的功能是支持增量备份,增量备份中心思想就是减少备份的数据量,使用增量备份后就可以不用从头开始备份了,只需要备份自上次已备份之后的数据块开始进行数据备份。
- 关于Oracle 增量备份级别
Oracle 10g 官方文档明确指出增量备份只有 0 和 1 两种级别 (太多增量级别其实没有太大的意义),不过实际执行增量操作时,仍然能够指定多个级别,最大能够支持4级增量备份。
Oracle 11g 增量备份只有 0 和 1 两种级别 。
Level 0 级就是对数据库一个全库备份,增量备份必须从 0 级开始,也就是说必须要有一个全库备份当基础。如果你做全库备份 Oracle 也不认为这是 level 0 的全库备份,尽管是一样的也要单独做一次 level 0 。有了 level 0 当基础才能有后面的 level 1 level 2 level 3 level 4。
- 增量备份原理
Oracle 的增量备份分为差异增量备份(Differential Incremental Backup)和积累增量备份(Cumulative Incremental Backup)两种 。
- 差异增量备份(Differential Incremental Backup)
例如:我们在星期天执行 Level 0 级差异增量备份操作,这个备份操作会备份整个数据库。根据这个 Level 0 级备份,我们在星期一执行 Level 1 级差异增量备份操作。该备份操作将备份自周日 Level 0 级备份以来所有发生变化的数据块。在周二时 Level 1 级增量备份将备份所有自周一 Level 1 级备份以来发生变化的数据块。如果要执行恢复操作,就需要星期一、星期二生成的备份以及星期天生成的基本备份。下面是一个执行 Level 1 级差异增量备份操作的示例:
backup incremental level=1 database;
- 累计增量备份(Cumulative Incremental Backup)
例如:我们在星期天执行 Level 0 级差异增量备份操作,此时会备份整个数据库。随后,我们星期一执行 Level 1 级备份操作,这种备份不同于差异备份,在星期二进行另一个 Level 1 级差异备份操作。需要注意的是:星期二生成的备份不仅包含星期一的差异备份以后发生变化的数据块,而且还含有星期一生成的备份中所包含的数据块。因此,累积备份累积了任何同级或低级增量备份操作包含的所有发生变化的数据块。如果要执行恢复操作,就只需要星期二生成的备份以及星期天生成的基本备份。
下面是一个执行 Level 1 级累积增量备份操作的示例:
backup incremental level=1 cumulative database;
- 差异增量备份与累积增量备份比较
差异增量备份: 速度较快、因为仅存储少量变化的块、但需要更长的时间来恢复;
积累增量备份: 主要优势是恢复时间较短、缺点是备份时间长和磁盘开销大;
积累增量备份: 主要优势是恢复时间较短、缺点是备份时间长和磁盘开销大;