本文共 2355 字,大约阅读时间需要 7 分钟。
和大家分享下有关于备份和恢复的10个最佳的实践。
1.开启块检查。
这样做的目标是尽早发现数据库中的坏块。这只会占用很少的性能开销,但却可以让 Oracle 尽早检测出由底层磁盘、存储系统、或 I/O 系统问题导致的坏块。SQL> alter system set db_block_checking = true scope=both;
2.使用 RMAN 增量备份时开启块更改跟踪(Block Change Tracking)功能(10g 及更高版本)。
更改跟踪文件包含了可以使 RMAN 增量备份进程避免读取自上次备份以来未修改的数据所需要的信息。如果不使用块更改跟踪功能,则必须读取所有块来确定自上次备份以来是否对其进行了修改。SQL> alter database enable block change tracking using file '/u01/oradata/ora1/change_tracking.f';3.镜像 重做日志组和成员,并将归档日志存放在多个目标位置。
通过在多个位置存放多个副本,当某个归档日志损坏或丢失时,其他日志仍然存在并可以使用。
如果某个在线日志被删除或损坏,在需要时还可以使用其他成员进行恢复。SQL> alter system set log_archive_dest_2='location=/new/location/archive2' scope=both;SQL> alter database add logfile member '/new/location/redo21.log' to group 1;
RMAN> backup check logical database plus archivelog delete input;
如果使用 RMAN,可以使用以下命令执行此操作:
RMAN> restore validate database;
然而,如果 filesperset 的值很小,也会导致创建更多的备份片,因而会降低备份性能并增加维护操作时间。因此必须根据所需的恢复时间要求对这些因素加以权衡。
RMAN> backup database filesperset 1 plus archivelog delete input;
SQL> alter system set control_file_record_keep_time=21 scope=both;
这会将备份记录在控制文件中保留 21 天。
定期运行以下目录维护命令。
原因:Delete obsolete 将删除保留策略以外的备份。如果过期的备份未删除,则目录将不断增长,直至出现性能问题。RMAN> delete obsolete;原因:crosschecking 将检查目录/控制文件是否与物理备份匹配。如果某个备份丢失,此命令会将该备份片 设为“EXPIRED”,在开始恢复时,将不使用这个备份,而使用更早的备份。要删除目录/控制文件中已过期的备份,请使用 delete expired 命令。RMAN> crosscheck backup;RMAN> delete expired backup;
这将确保您始终能够拥有最新的控制文件,控制文件备份在当前备份结束时执行,而不是在备份期间。
RMAN> configure controlfile autobackup on;
保留备份日志
原因:备份日志包含了磁带存取的参数、控制文件备份的位置,如果所有文件都丢失了,则可以利用该日志。SQL> recover database test;
本文转自ICT时空 dbasdk博客,原文链接: ,如需转载请自行联系原博主。