ORACLE10GRMAN管理的备份与恢复手册.doc

上传人:文库蛋蛋多 文档编号:2392091 上传时间:2023-02-17 格式:DOC 页数:96 大小:302.50KB
返回 下载 相关 举报
ORACLE10GRMAN管理的备份与恢复手册.doc_第1页
第1页 / 共96页
ORACLE10GRMAN管理的备份与恢复手册.doc_第2页
第2页 / 共96页
ORACLE10GRMAN管理的备份与恢复手册.doc_第3页
第3页 / 共96页
ORACLE10GRMAN管理的备份与恢复手册.doc_第4页
第4页 / 共96页
ORACLE10GRMAN管理的备份与恢复手册.doc_第5页
第5页 / 共96页
点击查看更多>>
资源描述

《ORACLE10GRMAN管理的备份与恢复手册.doc》由会员分享,可在线阅读,更多相关《ORACLE10GRMAN管理的备份与恢复手册.doc(96页珍藏版)》请在三一办公上搜索。

1、ORACLE10g RAMN管理的备份与恢复手册版本信息版本作者时间备注目录第一部分 概述61.数据库备份与恢复综述61.1.Oracle失败61.2.备份与恢复基础61.2.1.备份与恢复方法61.2.2.制定恢复策略61.2.3.Oracle10g备份与恢复新特征72.Oracle恢复结构72.1.Oracle服务器72.2.建立示例数据库72.3.备份与恢复配置72.3.1.多元化控制文件72.3.2.多元化重做日志82.3.3.配置例程恢复参数83.配置日志操作模式103.1.日志操作模式简介103.2.改变日志操作模式103.3.配置其他归档参数103.4.显示归档信息12第三部分

2、RMAN管理的备份与恢复124.RMAN基础134.1.RMAN组成134.1.1.RMAN组件134.1.2.RMAN的特点134.2.运行RMAN144.2.1.连接到RMAN144.2.2.RMAN命令154.3.配置RMAN环境175.RMAN备份195.1.RMAN备份的概念195.2.建立备份集205.3.建立映像副本235.4.建立增量备份和累积备份245.5.显示备份信息256.RMAN恢复266.1.RMAN恢复综述266.2.RMAN完全恢复286.2.1.恢复数据库286.2.2.恢复SYSTEM表空间的数据文件296.2.3.在OPEN状态下恢复关闭后意外丢失的数据文件

3、306.2.4.在OPEN状态下恢复打开时意外丢失的数据文件316.2.5.在OPEN状态下恢复未备份的数据文件326.2.6.恢复表空间336.2.7.数据块介质恢复346.3.RMAN不完全恢复346.3.1.基于时间恢复346.3.2.基于SCN恢复356.3.3.基于日志序列号恢复366.3.4.基于备份控制文件恢复377.RMAN维护命令387.1.REPORT387.2.LIST397.3.CROSSCHECK417.4.DELETE437.5.CHANGE447.6.CATALOG458.管理恢复目录468.1.恢复目录简介468.2.建立恢复目录488.3.使用存储脚本498.

4、4.维护恢复目录508.5.查询恢复目录53第四部分 逻辑备份与恢复549.EXPDP和IMPDP549.1.EXPDP和IMPDP简介549.2.使用EXPDP549.3.使用IMPDP559.4.使用EXPDP和IMPDP 搬移 表空间5510.EXP和IMP5710.1.EXP和IMP简介5710.2.使用EXP5710.3.使用IMP5710.4.使用EXP和IMP 搬移 表空间58第五部分 备份和恢复高级知识5911.表空间时间点恢复5911.1.TSPITR简介5911.2.准备TSPITR6011.3.实现管理的TSPITR6011.3.1.全自动TSPITR6011.3.2.用

5、自动辅助例程定制TSPITR6011.3.3.手工辅助例程实现TSPITR6212.管理复制数据库6312.1.复制数据库综述6312.2.RMAN管理的复制数据库6412.2.1.在同一主机上建立RMAN管理的复制数据库6512.2.2.在不同主机上建立RMAN管理的复制数据库6813.物理备用数据库7013.1.Data Guard综述7013.2.使用RMAN备份建立物理备用数据库7113.2.1.在相同主机上使用RMAN备份建立物理备用数据库7213.2.2.在不同主机上使用RMAN备份建立物理备用数据库7513.3.管理物理备用数据库7914.逻辑备用数据库8114.1.逻辑备用数据

6、库综述8114.2.建立逻辑备用数据库8314.3.管理逻辑备用数据库8715.备份和恢复相关工具8915.1.LogMiner8915.2.DBVERIFY9215.3.DBNEWID93第一部分 概述1. 数据库备份与恢复综述1.1. Oracle失败 语句失败 用户错误 用户进程失败 网络失败 例程失败 介质失败u 恢复数据库u 重建数据库1.2. 备份与恢复基础1.2.1. 备份与恢复方法1.2.2. 制定恢复策略SQLshutdown immediate;1.2.3. Oracle10g备份与恢复新特征SQLshutdown abort;2. Oracle恢复结构2.1. Oracl

7、e服务器2.2. 建立示例数据库 2.3. 备份与恢复配置2.3.1. 多元化控制文件SQLselect name from v$controlfile;SQLalter system set control_files=d:democontrol01.ctl,d:democontrol02.ctl,d:democontrol03.ctl,c:democontrol04.ctl scope=spfile;SQLshutdown immediateSQLhost copy d:democontrol01.ctl c:democontrol04.ctlSQLstartupSQLselect nam

8、e from v$controlfile;2.3.2. 多元化重做日志SQLselect group#,members,status,bytes from v$log;SQLselect member from v$logfile;将同一个日志组的不同日志成员分布到不同磁盘(新增日志成员放到C盘)。SQLalter database add logfile member c:demoredo01_1.log to group 1, c:demoredo02_2.log to group 2, c:demoredo03_2.log to group 3;SQLselect group#, mem

9、ber, status from v$logfile;2.3.3. 配置例程恢复参数 例程恢复是指当出现例程失败时由后台进程SMON自动同步数据文件、控制文件和重做日志并打开数据库的过程。 例程恢复时间由需要应用的脏缓冲区块个数确定,脏缓冲区块个数的最大值由检查点来确定,以下初始化参数可以用于控制检查点,如:u fast_start_mttr_target: 用于指定例程恢复的最大时间(单位: 秒)u log_checkpoint_timeout: 用于指定发出检查点的时间间隔(单位: 秒)u log_checkpoint_inteval: 用于指定发出检查点的重做日志块间隔(单位: OS块)

10、后面两个参数是为了与早期版本兼容而保留的,建议使用fast_start_mttr_target控制例程恢复的时间。 参数FAST_START_MTTR_TARGET设置方法:SQL ALTER SYSTEM SET FAST_START_MTTR_TARGET=900; -(15分钟) 监视例程恢复的动态信息SQLselect actual_redo_blks, target_redo_blks, estimated_mttr from v$instance_recovery;estimated_mttr用于标志例程恢复的预计时间。因为例程恢复时间主要由REDO时间和UNDO时间确定,所以为了

11、降低例程恢复的实际时间,应该调整REDO和UNDO的时间。 调整REDO时间为了降低例程恢复的REDO时间,可以启动多个SLAVE进程。通过配置静态初始化参数recovery_parallelism, 可以指定SLAVE进程的个数。修改该参数后要重启例程才生效。SQLALTER SYSTEM SET RECOVERY_PARALLELISM=3 SCOPE=SPFILE;SQLSHUTDOWN IMMEDIATESQLSTARTUP 调整UNDO时间为了降低例程恢复的UNDO时间,可以启动多个SLAVE进程。通过配置参数FAST_START_PARALLEL_ROLLBACK可以控制SLAVE

12、进程的个数。该参数可以取三个值: u FALSE: 不启用SLAVE进程u LOW: 启用SLAVE进程个数为2倍的CPU个数u HIGH: 启用SLAVE进程个数为4倍的CPU个数SQLALTER SYSTEM SET FAST_START_PARALLEL_ROLLBACK=HIGH;监视执行UNDO操作的进程信息:SQLselect pid, state, undoblocksdone from v$fast_start_servers;监视事务恢复的信息:SQLselect pid, undoblocksdone, undoblockstotal from v$fast_start_t

13、ransactions; 实战:监视例程恢复SCOTT建立会话, 并执行:Create table demo_tab(cola int, colb int);Begin For i in 1.100000 loop Insert into demo_tab values(i, i); End loop;END;/同时,在SYS会话中执行 SHUTDOWN ABORT 命令关闭数据库,然后执行STARTUP 重启数据库。在数据库打开后,监视事务恢复的进度。3. 配置日志操作模式3.1. 日志操作模式简介 NOARCHIVELOG ARCHIVELOG3.2. 改变日志操作模式 检查当前日志操作模

14、式Sqlplus sys/oracledemo as sysdbaSQLselect log_mode from v$database; 改变日志操作模式SQLSHUTDOWN IMMEDIATESQLSTARTUP MOUNTSQLALTER DATABASE ARCHIVELOG; - NOARCHIVELOGSQLALTER DATABASE OPEN;3.3. 配置其他归档参数 配置归档日志的名称格式静态初始化参数log_archive_format用于指定归档日志的文件名格式。可以指定的匹配符:u %s : 日志序列号u %S : 日志序列号(带有前导0)u %t : 重做线程号u

15、%T : 重做线程号(带有前导0)u %a : 活动ID号u %d : 数据库ID号u %r : RESETLOGS的ID值设置语句:SQLalter system set log_archive_format=ARC_%s_%t_%r.log scope=SPFILE;SQLshutdown immediateSQLstartup注意:如果归档日志被存放在快速恢复区,那么归当日志文件名格式不受此参数约束. 使用log_archive_dest_n配置归档日志的位置配置本地归档位置的语句:SQLalter system set log_archive_dest_1=location=c:dem

16、oarchive;SQLalter system set log_archive_dest_2=location=d:demoarchive;配置远程归档位置的语句:service选项指定到备用数据库的网络服务名.SQLalter system set log_archive_dest_3=service=standby; log_archive_dest_n的其他常用选项u OPTIONAL : 默认选项。表示无论归档是否成功,都可以覆盖重做日志。u MANDATORY:强制归档。表示只有在归档成功之后,重做日志才能被覆盖。u REOPEN:指定重新归档的时间间隔,默认值300秒。注意:RE

17、OPEN属性必须跟在MANDATORY选项后。示例:SQLalter system set log_archive_dest_1=location=c:demoarchive optional;SQLalter system set log_archive_dest_1=location=d:demoarchive mandatory; 使用log_archive_dest_state_n控制归档位置的可用性禁用相应的归档位置2: deferSQL alter system set log_archive_dest_state_2=DEFER;激活相应的归档位置2: enableSQL alt

18、er system set log_archive_dest_state_2=ENABLE; 使用log_archive_max_processes控制归档进程的个数从而可以动态增加或减少归档进程的个数。SQL alter system set log_archive_max_processes=3; 使用log_archive_min_succeed_dest控制本地归档的最小成功个数SQLalter system set log_archive_min_succeed_dest=2;注:若小于,则重做日志不能被覆盖 使用log_archive_dest和log_archive_duplex

19、_dest配置归档位置注:此两参数是为了兼容以往版本保留的,不能与log_archive_dest_n同时使用.SQLalter system set log_archive_dest=location=d:demoarchive1;SQLalter system set log_archive_duplex_dest=location=d:demoarchive2;3.4. 显示归档信息 使用archive log list命令SQL archive log list; 显示日志操作模式SQL select name,log_mode from v$database; 显示归档日志信息SQL

20、 col name format a40;SQL select name,sequence#,first_change# from v$archived_log; 显示归档日志的位置SQL col archive_dest format a20;SQL col destination format a20;SQL select archive_dest,destination,status from v$archive_dest; 显示日志历史信息SQL select * from v$loghist; 显示归档进程信息SQL select * from v$archive_processes

21、;第二部分 RMAN管理的备份与恢复4. RMAN基础4.1. RMAN组成4.1.1. RMAN组件. 了解RMAN的基本组件及功能. 学会连接到RMAN. 学会配置RMAN环境RMAN(Recovery Manager,恢复管理器)是Oracle所提供的实用程序,它可以协助DBA管理备份,转储和恢复操作.(RMAN的备份和恢复操作也称为服务器管理的备份和恢复)1. 目标数据库(target database)2. 服务器进程3. 通道(Channel)4. RMAN资料库(Recovery Manager Repository)和 RMAN元数据(Recovery Manager Meta

22、data).RMAN元数据是指RMAN在备份,转储和恢复操作中所使用的数据.RMAN元数据的集合被称为RMAN资料库5. 恢复目录.通过使用恢复目录,可以永久保留需要的RMAN元数据;.另外,在恢复目录中还可以存放存储脚本.6. 介质管理层(Media Management Layer)7.RMAN包4.1.2. RMAN的特点1. 备份数据库,表空间,数据文件,控制文件,归档日志和SPFILE2. 存储频繁执行的备份和恢复操作.注意:如果使用存储脚本,则必须配置恢复目录3. 跳过未用块.使用RMAN生成备份集,那么只会备份已经使用的数据块,而跳过未用的数据块.因而使用RMAN备份集更加节省存

23、储空间.4. 执行增量块级备份.当使用RMAN生成备份集(backup set)时,可以使用增量备份和累积备份减少备份时间。.如果使用增量备份,那么只备份先前备份以来变化的数据块,从而大大减少了备份时间.5. 指定备份限制.可以指定备份集最大尺寸和备份片最大尺寸.通过限制备份片的最大尺寸,可以有效地将一个备份集的内容分布到多个磁盘上.6. 在备份时检测损坏块.使用用户备份,必须使用DBVERIFY工具进行检测.使用RMAN,可以查看v$backup_corruption, v$copy_corruption7. 自动使用并行化特征提高备份和恢复性能.使用RMAN执行操作时,若数据库所在服务器有

24、多个CPU,那么在执行操作前可以分配多个通道.当分配多个通道后,RMAN会自动启用多个服务器进程执行备份和恢复操作,从而提高了备份和恢复的性能.4.2. 运行RMAN4.2.1. 连接到RMAN1. 连接到目标数据库(不使用恢复目录)c:rman target sys/oracledemo nocatalog或c:rman nocatalogRMANconnect target sys/oracledemo2. 连接到目标数据库和恢复目录数据库c:rman target sys/oracledemo catalog rman/rmanrcat或c:rmanRMANconnect target

25、sys/oracledemoRMANconnect catalog rman/rmanrcat3. 连接到目标数据库和辅助数据库c:rman target sys/oracledemo auxiliary sys/adminaux或c:rmanRMANconnect target sys/oracledemoRMANconnect auxiliary sys/adminaux4.2.2. RMAN命令1. 独立命令(1) 关闭目标数据库RMANshutdown immediate(2) 启动目标数据库RMANstartup(3) 备份USERS表空间RMANbackup format d:ba

26、ckup%d_%s.bak tablespace users;2. 作业命令.当使用作业命令时,必须将这些相关RMAN命令放在RUN块中.注意:除了 CONNECT,create/delete/update catalog,create/delete/replace script,list等RMAN命令外,其他RMAN命令都可以被包含在RUN块内.示例如下:RMANrun allocate channel d1 type disk;backup format d:backup%d_%s.bak tablespace users;release channel d1;3. 运行SQL命令.在RM

27、AN提示符下不仅可以运行RMAN命令,还可以运行SQL语句.但当运行SQL语句时,必须以关键字SQL开始,并且SQL语句字符串必须用单引号引住.注意: 如果SQL字符串包含有单引号,那么需要用两个单引号,并且SQL语句字符串需要用双引号引住.如下:RMANsql alter system switch logfile;RMANsql create tablespace user03 datafile d:demouser03.dbf size 5M;4. 运行存储脚本RMANrun execute script s1;5. 运行操作系统命令RMANrun host dir d:backup;6

28、. 运行RMAN命令.命令行交互方式,如下:c:rman target sys/oracledemoRMANrun configure channel device type disk maxpiecesize 100M; backup format d:backup%d_%s_%p.BAK tablespace system;.批处理方式运行.批处理方式是指将RMAN命令存放到命令文件中,然后在RMAN命令行直接运行该命令文件.通过使用批处理文件,不仅可以避免交互方式的命令错误,而且可以由操作系统作业定期执行备份操作.命令文件bak_users.cmd的示例如下: backup format

29、 d:backup%d_%s.bak tablespace users;sql alter system archive log current;.为了取得批处理的运行信息,可以使用LOG选项指定日志文件.以批处理方式运行该命令脚本的示例如下: RMAN target sys/oracledemo nocatalog c:bak_users.cmd log a.log4.3. 配置RMAN环境1. 配置自动通道(1) 配置自动通道并行度RMANconfigure device type disk parallelism 3;(磁盘)RMANconfigure device type sbt p

30、arallelism 3;(磁带)(2) 配置所有通道的备份文件格式RMANconfigure channel device type disk format d:backup%d_%s_%p.bak;(3) 配置特定通道的备份文件格式RMANconfigure channel 1 device type disk format d:backup%d_%s_%p.bak;RMANconfigure channel 2 device type disk format d:backup%u.bak;(4) 配置默认存储设备RMANconfigure default device type to s

31、bt;RMANconfigure default device type to disk;2. 配置备份集和备份片最大尺寸RMANconfigure maxsetsize to 1G;RMANconfigure channel device type disk maxpiecesize 500M;3. 配置备份优化.注意: 备份优化只适合用于backup database, backup archivelog all/like和backup backupset all命令.默认情况下,RMAN禁止备份优化.激活备份优化的示例如下:RMANconfigure backup optimizatio

32、n on;4. 配置多重备份RMANconfigure datafile backup copies for device type disk to 3;5. 配置免除表空间.比如用来测试的表空间,备份时就可以免除该表空间.RMANconfigure exclude for tablespace user03;6. 配置备份冗余策略RMANconfigure retention policy to redundancy 2;7. 配置辅助例程的数据文件名RMANconfigure auxname for datafile 2 to d:auxidf_2.dbf;8. 配置快照控制文件名RMAN

33、configure snapshot controlfile name to d:oracleora10snfcDEMO.ORA;9. 显示RMAN配置(1) 显示所有RMAN环境配置RMANshow all;(2) 显示默认设备类型RMANshow default device type;(3) 显示自动通道配置RMANshow channel for device type disk;(4) 显示备份冗余策略RMANshow retention policy;(5) 显示备份优化RMANshow backup optimization;(6) 显示快照控制文件RMANshow snapsh

34、ot controlfile name;(7) 显示备份集最大尺寸RMANshow maxsetsize;(8) 显示多重备份RMANshow datafile backup copies;-(数据文件多重备份信息)RMANshow archivelog backup copies;-(归档日志多重备份信息)(9) 清除RMAN配置.使用CONFIGURE命令可以配置RMAN环境,如果要将RMAN配置修改为默认配置,则可以使用clear选项清除相应的RMAN配置.示例如下:RMANconfigure retention policy clear;5. RMAN备份5.1. RMAN备份的概念.

35、使用 backup 建立备份集.使用 backup as copy 或 copy 命令建立映像副本.使用增量备份和累积备份1. 备份集(Backup Set).备份集只能用RMAN命令建立和转储.备份集是RMAN所提供的一种用于存储备份信息的逻辑结构.2. 备份片(Backup Piece).备份片是用于存储备份信息的二进制文件.备份集由一个或多个备份片组成.每个备份片对应一个OS文件. 3. 映像副本 .映像副本类似于用户管理的备份,它是单个数据文件,单个控制文件或单个归档日志的完整备份文件. .注意:映像副本只能备份到磁盘,而不能备份到磁带.5.2. 建立备份集.备份集是RMAN所提供的一

36、种用于存储备份信息的逻辑结构,它由一个或多个备份片组成。为了避免备份集建立错误,在指定备份片的文件格式时应该使用以下匹配符:. %c: 当生成多重备份时,用于指定备份片的副本号. %d: 用于指定数据库名. %e: 用于指定归档日志序列号. %p: 用于指定在备份集内备份片的编号. %s: 用于指定备份集编号. %N: 用于指定表空间的名称. %f: 用于指定绝对文件号%T,%u,%U. 为了防止建立备份集错误,匹配符%s是必须的;. 如果要建立多个备份片文件,则匹配符%p是必须的;. 如果要建立多个备份片副本,则匹配符%c是必须的.1. 完全数据库备份集(1) 一致性备份C:rman tar

37、get sys/oracledemo nocatalogRMANshutdown immediateRMANstartup mountRMANbackup database format=d:backup%d_%s.dbf;RMANsql alter system archive log current;.当执行了backup database命令之后,不仅会备份所有数据文件,而且会自动备份控制文件.注意: 当备份数据文件1后,会自动备份当前控制文件.(2) 非一致性备份RMANbackup database format=d:backup%d_%s.dbf;RMANsql alter sys

38、tem archive log current;(3) 免除表空间RMANconfigure exclude for tablespace user03;RMANbackup database format=d:backup%d_%s.dbf;RMANsql alter system archive log current;2. 表空间备份集.表空间备份集是指使用backup tablespace命令备份一个或多个表空间的方法.注意:备份表空间只适用于ARCHIVELOG模式,并且要求数据库处于OPEN状态.如下:RMANbackup tablespace user03 format=d:ba

39、ckup%N_%s.dbf;3. 数据文件备份集.数据文件备份集是指使用backup datafile命令备份一个或多个数据文件的方法.注意:当执行backup datafile命令时,数据库既可以处于MOUNT状态,也可以处于OPEN状态.如下:RMANbackup datafile 5 format=d:backup%N_%f_%s.dbf;4. 控制文件备份集.控制文件备份集是指使用backup current controlfile命令备份当前控制文件的方法.如下:RMANbackup current controlfile format=d:backup%d_%s.ctl;.注意:当

40、备份数据文件1时,会自动备份当前控制文件.当备份其他数据文件时,通过指定INCLUDE CURRENT CONTROLFILE选项可以同时备份控制文件如下:RMANbackup datafile 5 format=d:backup%d_%s.dbf include current controlfile;5. SPFILE备份集.SPFILE备份集是指使用backup spfile命令备份服务器参数文件的方法.如下:RMANbackup spfile format=d:backup%d_%s.par;6. 归档日志备份集.归档日志备份集是指使用backup archivelog命令备份归档日志

41、的方法.如下:RMANbackup format=d:backup%d_%s.arc archivelog from time=sysdate-1 until time=sysdate;-7. 并行化备份集.什么是并行化备份集?示例如下:RMANconfigure device type disk parallelism 3;RMANbackup database format=d:backup%d_%s.dbf;RMANconfigure device type disk clear;(备份完后,清除配置的并行度,复原)8. 建立多重备份.下面以备份users表空间,并生成三个备份副本为例,

42、说明建立多重备份的方法.如下:RMANbackup copies 3 tablespace users format=d:bak1%N_%s.dbf, d:bak2%N_%s.dbf,d:bak3%N_%s.dbf;.注意:当建立多重备份时,如果多重备份被存放到相同目录下,则必须要带有%c匹配符.9. 备份备份集.备份备份集是指使用backup backupset命令备份已存在备份集的方法.下面以将以编号为32的备份集备份到D:BAK1目录为例,说明备份备份集的方法.示例如下:RMANbackup backupset 32 format=d:bak1%d_%s.bak;10. 建立多个备份片.

43、注意:当建立多个备份片时,必须要指定%p匹配符.下面以限制备份片最大尺寸4G为例,说明建立多个备份片的方法.如下:RMANconfigure channel device type sbt maxpiecesize 4G;RMANbackup device type sbt format %d_%s_%p.dbf database;11. 建立压缩备份集.使用backup 命令的 AS COMPRESSED BACKUPSET 选项,示例如下:RMANbackup as compressed backupset tablespace users format=d:backup%d_%s.dbf;12. 备份数据文件和归档日志.当建立备份集时,RMAN会将不同类型的文件分布到不同备份集中.当使用BACKUP命令备份数据文件时,通过指定PLUS ARCHIVELOG选项可以同时备份归档日志.如下:RMANbackup format d:backup%d_%s.bak tablespace user01 plus archivelog;13. 指定备份集标

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号