RMAN说,我能备份(14)--实战RMAN备份

涂抹ORACLE试阅章节:第8章-Rman说,我能备份

===========================================================================

8.6 实战RMAN备份

  通过前面的若干示例,我们已经了解并尝试了RMAN备份的一些命令,但是在实际环境中,不可能每次备份都要求DBA一条命令一条命令来敲(DBA手指头都痉挛啦,老板看着更是肉疼,早知道就是打几个字母,雇个打字的,成本不是更低么),通过前面章节的学习我们立志一定要优化的干活,所以我们应该写好一段脚本,然后放在服务器端定时执行。DBA只需要定期看看脚本执行的结果就成了。

  在真正写脚本之前,先明确一下我们的目标:

  • 每天夜间1点执行。
  • 数据库全备,同时备份控制文件及归档日志文件,备份文件保存至F:\oracle\backup\目录下,并在完成归档日志文件备份后,自动删除已备份的归档日志。
  • 备份保留14天,过期则自动删除。
  • 保留操作日志备查。

  以Windows环境为例(Linux/U NIX 环境下与此基本类似,对于RMAN的脚本,甚至连改都不用改,就把调用RMAN脚本的命令行以及备份集保存路径改改就行了!

8.6.1 编写 RMAN 批处理文件

  编写RMAN批处理文件:

RUN {

 CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 14 DAYS;

 CONFIGURE CONTROLFILE AUTOBACKUP ON;

 CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVICE TYPE DISK TO  ' F:\ORACLE\BACKUP\%F ' ;

 ALLOCATE CHANNEL C1 DEVICE TYPE DISK FORMAT  ' F:\ORACLE\BACKUP\BAK_%U ' ;

 BACKUP DATABASE SKIP INACCESSIBLE 

   PLUS ARCHIVELOG FILESPERSET 20

   DELETE ALL INPUT;

 RELEASE CHANNEL C1;

 }

 ALLOCATE CHANNEL FOR MAINTENANCE DEVICE TYPE DISK;

 CROSSCHECK BACKUPSET;

 DELETE NOPROMPT OBSOLETE;

  保存至F: \oracle\script\backup\db_fullbak_jssbook.rman 。

提示:

前几行中的CONFIGURE命令也可以放到批处理脚本之外执行,只需要执行一次即可,因为所有的CONFIGURE配置都将存入目标端数据库的控制文件,只要无人改过就一直有效。

  上述的各项命令均在前面几个章节中提到过,如果有看着眼生的话,再回去翻看前面的内容。命令是都知晓,可能有几个参数会不明白其意义。

  比如:BACKUP命令中的SKIP INACCESSIBLE参数,大家别着急,静心等候俺的外……外外……外外外……(大锅,看个笔记而已,您不用拎着把菜刀到处晃吧,你你你,你别过来,我说还不成嘛), en ,看到大家如此虔诚,俺就提前透露这部分内容吧。

(1)BACKUP SKIP参数。

  SKIP INACCESSIBLE :表示跳过不可读的文件。我们知道一些 OFFLINE 状态的数据文件只要存在于磁盘上就仍然可能被读取,但是可能有些文件已经被删除或移到它处而不可读,加上这个参数就会跳过这些文件。

  SKIP OFFLINE :表示跳过 OFFLINE 的数据文件;

  SKIP READONLY :表示跳过那些所在表空间为 READ   ONLY 的数据文件。

(2)FILESPERSET参数。

  该参数用来设置一个备份集中最多能够包含的文件。本例中是出现在备份归档的子句中,因此用来限制每个归档备份集中最多只能包括20个归档文件,如果有超过20个归档文件需要备份的话,那么在执行备份时会创建多个归档文件的备份集。

  使用BACKUP命令备份其他类型的文件(除了备份集),也支持FILESPERSET参数,作用是相同的。

(3)ALLOCATE CHANNEL FOR MAINTENANCE命令。

  这个命令乍看与ALLOCATE CHANNEL非常相似,再看还是相似,其实也确实是相似(俺是说相似,没说相同),ALLOCATE CHANNEL FOR MAINTENANCE命令也是用来分配通道的,但分配的通道专用于CHANGE、DELETE、CROSSCHECK命令,并且也不需要(而且也不能)包含在RUN块中。

  默认配置下CONFIGURE已经分配了一个指定 DISK 的通道,因此也可以不需要执行ALLOCATE CHANNEL FOR MAINTENANCE命令,另外Oracle也建议通过CONFIGURE分配通道,来替代使用该命令维护管理用的专用通道,这可能会增强备份脚本的复杂度。

提示:

如果你试过从网上搜索RMAN备份脚本,可能有些脚本中会出现一行“sql 'alter system archive log current';”,这句是让 ARCHIVELOG 日志归档,实际上完全没必要,我们在前面的内容中讲过,通过 PLUS ARCHIVELOG 方式备份时, RMAN 会自动对当前的 ARCHIVELOG 进行归档。

8.6.2 编写命令执行批处理

  设定要备份的数据库SID为 jssbook ,将日志按照日期输出到F:\ oracle\script\backup\logs \ 目录。

SET ORACLE_SID=jssbook

RMAN TARGET/LOG F:\ORACLE\SCRIPT\BACKUP\LOGS\BAK_%DATE: ~ 0,10%.LOG CMDFILE= F:\ORACLE\SCRIPT\BACKUP\ DB_FULLBAK_JSSBOOK.RMAN

  将上述内容保存至F:\ oracle\script\backup\db_fullbak_jssbook.bat 。

8.6.3 设定执行计划

  利用“控制面板”中的“任务计划”中的“添加任务计划”图标添加计划,运行F:\ oracle\script\backup\db_fullbak_jssbook.bat ,设定日程安排中的时间为指定中的时间。

  竣工!

  说是实战,实际上演练的味道依然浓厚,谁让咱这是在测试呢。上述脚本已初具雏形,当然还应该再增加一些更合理的配置,比如根据您的数据库大小,适当调整通道数量,以及加上日期的判断,根据时间进行增量备份。

  对于小型数据库(不超100GB)的备份相对来说还是很简单的,甚至每次备份都是完全备份也可以接受,因此在备份策略上能够非常灵活,或者说随意。对于那些数百G甚至过T的数据库,我想就需要花些心思来考虑备份策略的问题了。

  对于超大型数据库的备份,基本上就没有什么固定套路,毕竟系统环境、存储设备及应用的特点都是不同的,不过有一点我想毋庸置疑:备份的目的是为了更好的恢复,因此做好备份与恢复之间开销的平衡应该是所有备份策略的终极目标。

  备份终于完了。不过别松气,这仅仅只是开始,加油!

=================================================

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7607759/viewspace-627899/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/7607759/viewspace-627899/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RMAN学习测试整理1 20121219 by Apollo 一、 Oracle数据库备份分为物理备份和逻辑备份。今天测试整理下物理备份Rman,也就是oracle的恢复管理器(Recovery Manager)。 毕竟逻辑备份是不能实现时间点恢复的,所以生产数据库肯定用物理备份来保证灾难时能够恢复。 二、 Rman备份的前提条件:数据库需要运行在归档模式下 (1) 查看oracle数据库的archivelog mode的方式 sqlplus / as sysdba ##需要as sysdba登录,不然即使有dba权限也fail archive log list ##方式一 select name,log_mode from v$database; ##方式二 (2) 由非归档切换到归档模式 shutdown immediate startup mount alter database archivelog; alter database open; (3) 反之由归档切换到非归档模式 shutdown immediate startup mount alter database noarchivelog; ##切换到非归档 alter database open; (4) 其实oracle安装好后会默认运行在非归档模式下(安装时有开关勾选),其配置文件为init.ora,可以通过修改init.ora来调整。 sqlplus oracle/oracle show parameter spfile ##spfile和init.ora一般在一个路径下 exit cd $ORACLE_HOME/dbs vi init.ora (5) init.ora关于archive的参数 log_archive_start = true 启动自动归档 log_archive_dest = disk$rdbms:[oracle.archive] 归档日志路径 log_archive_format = “T%TS%S.ARC” 归档日志格式 三、 启用数据库备份模式 (1) 查看当前情况 select * from v$backup; select * from v$log select * from v$datafile_header (2) 整库开启备份模式alter database begin backup; 哦,忘记开启归档了。奔3的人老了呀。(非一致性备份必须开启归档) (3) 指定某个表空间开启备份模式 alter tablespace tablespace_name begin backup; 先建个tbs_apollo_backup的表空间吧: 靠,/opt下剩余只有649M,先给个200M吧,回头再从根目录划分一些出来。 create tablespace tbs_apollo_backup datafile '/opt/oracle/oradata/orcl/tbs_apollo_backup.dbf' size 200M 因为之前做了database begin backup,所有表空间都处于backup状态了。将database的backup停掉重新指定tablespace备份。 再次查看各个tablespace的backup情况 select a.tablespace_name,b.status as backup_status,a.file#, a. ts#,a.recover,a.status as on_off_status,a.name from v$datafile_header a ,v$backup b where a.file# = b.file# 四、 RMAN相关使用 1、 RMAN连接到Target Database (1) 分步进行 rman nocatlog(nocatalog会将相关备份信息即元数据放在Contronfile里面) connect target / (不像DB2那样connect to,就connect就OK了) (2) 一步到位 rman nocatlog target system/manger 权限不足,使用rman连接target的话需要sysdba权限而不是dba。 I 查看是否拥有sysdba权限 select * from v$pwfile_users; 备注:常用的查看权限视图 select * from dba_users where username='SYSTEM' select * from dba_role_privs where grantee='SYSTEM'; select * from v$pwfile_users; ii 用sys用户授予system用户sysdba权限(其实是一个角色) iii 用system用户再次连接target database (3) 可以在rman里面停起数据库(停库状态需要隐式登录,不能带网络服务名) (4) DataFile tbs_apollo_backup.dbf异常了,先解决下 alter database datafile ‘datafile_name’ offline; recover datafile ‘datafile_name’ alter database datafile ‘datafile_name’ online; alter database open; 再次在Rman里面操作停起数据库(sql_statement用单引号或双引号括起) 2、 List命令查看备份集(在数据库控制文件或恢复目录中查询备份的历史信息的方法) (1) 查看数据库所有的备份集合 list backupset; (2) 查看指定TableSpace的备份 list copy of tablespace “TBS_APOLLO_BACKUP” list backupset of tablespace "TBS_APOLLO_BACKUP"; (3) 查看指定DataFile的备份 list backupset of datafile "/opt/oracle/oradata/orcl/users01.dbf"; (4) 查看备份汇总 list backup summary; (5) 3、 Report命令报告备份情况(判断数据库当前可恢复状态和提供数据库备份的信息) (1) report schema;(报告数据库结构) (2) report need backup;(报告需要备份的内容) (3) report obsolete(Which backups can be deleted ?)报告过期备份 (4) report unrecoberable(Which files are unrecoverable ?) 4、 CONFIGURE配置Rman参数 (1) show all命令查看所有配置 (2) CONFIGURE命令修改配置 ControlFile太重要了,一般都设置备份它 五、 准备下数据库对象 1、 临时表空间 create temporary tablespace apollo_temp tempfile ‘/opt/app/oracle/oradata/orcl_apollo/Apollo_temp.dbf’ size 200m autoextend on next 50m maxsize 2048m extent management local; 2、 创建数据表空间 create tablespace apollo_data logging datafile ‘/opt/app/oracle/oradata/orcl_apollo/apollo_data.dbf’ size 1g autoextend on next 50m maxsize 4096m extent management local; 备注:引用的字符串如这里的单引号在copy时异常。 3、 创建用户并指定表空间 create user rman identified by rman default tablespace apollo_data temporary tablespace apollo_temp; 4、 给用户授权 grant connect ,resource to rman; 5、 其他如table、index、function、procedure、view、sequence等。 六、 Rman备份的对象(主要包括Database、Tablespace、Datafile、Controlfile和Archivelog) Rman不能备份口令文件和初始化参数文件(也就是前面提到的init.ora)。 1、 备份DataBase backup database; backup database是一次全备份,其实省略的很多参数,相当于用的默认的。而备份好的备份集放在哪里呢? 在sqlplus里面执行show parameter db_recovery_file_dest; 查看备份后情况: list backupset; 2、 备份Tablespace backup tablespace apollo_data; RMAN-06554: WARNING: file 5 is in backup mode 该警告提示file5也就是这个表空间的备份其实已经存在了,因为刚做过full backup了嘛。 查看备份集合新增了3和4两个备份集 3、 备份Datafile backup datafile '/opt/app/oracle/oradata/orcl_apollo/system01.dbf'; 也可backup datafile 4 这里的4对应第四个datafile,可由report schema报告得知是:user01.dbf 测试备份的有点多,那么可以删除一些过期的备份。 (1) 通过删除备份集删除 (2) 通过删除备份片删除 (3) 当然直接删除全部过期更加直接 delete obsolete; (4) 删除后无过期备份存在 4、 备份Controlfile (1) 自动备份控制文件如前面示例show all后修改的参数 CONFIGURE CONTROLFILE AUTOBACKUP ON; 那么每次备份会自动备份控制文件。 (2) 手动备份控制文件 backup current controlfile; (3) 列出备份过的controlfile list backup of controlfile; 有14、15、16三个备份集里面有,那么肯定有过期的了,再验证下 report obsolete; 14和15作为过期的报告出来,16为最新的备份。 5、 备份Archivelog (1) 备份数据库时使用参数plus archivelog自动备份 backup database plus archivelog;(我们清空所有备份delete backup后重头来) (2) 手工备份 backup archivelog all; 6、 备份spfile (1) 备份时自动备份spfile CONFIGURE CONTROLFILE AUTOBACKUP ON在备份控制文件时页备份spfile (2) 手动备份 备份的spfile同样放到backupset目录下面 7、 七、 恢复数据库 1、 模拟datafile丢失或损坏进行恢复 cd $ORACLE_BASE/oradata/orcl_apollo mv ./apollo_data.dbf /home/oracle/backup/apollo_data.dbf 重启数据库看看 看来破坏了datafile正常停库都不行,需要abort才行。 起库就更不用了 那么开始真正恢复吧,思路是这样的:由报错可见起库的实例nomount和控制文件的mount都成功了,但是在open database时报错,就需要在mount和open之间恢复。先将datafile置于offline状态,restore和recover后在online,最后在open database就OK了。 (1) 将数据库处于mount模式 (2) 将datafile 1 (即system01.dbf)置于offline (3) restore和recover(所有的铺垫都是为了这两步) restore datafile 1; recover datafile 1; (4) 将datafile 1 置于online (5) alter database open; alter database datafile 2 offline; 2、 模拟tablespace丢失或损坏进行恢复 (1) backup tablespace apollo_data (2) drop tablespace apollo_data 提示表空间非空,查看下里面的内容,是建的一些测试表。 select * from dba_segments where tablespace_name='APOLLO_DATA' and segment_name=’ AMIS_IC_MEMBER’ ; 没关系那就加上including contents选项删除吧 (3) 停库起到mount模式 (4) 进入sqplus将表空间offline alter tablespace apollo_data offline; (5) 进入rman使用restore和recover恢复表空间 restore tablespace apollo_data; recover tablespace apollo_data; 备注:从(4)、(5)开始的执行都没有成功,因为drop表空间后即使在系统表里 面也不再有改表空间的信息,模拟失败待后续研究! (1) 在rman里面备份表空间apollo_data (2) 模拟表空间里面的对象破坏进行恢复吧 select * from dba_segments where tablespace_name='APOLLO_DATA' and (3) alter tablespace apollo_data offline; (4) restore tablespace apollo_data; (5) recover tablespace apollo_data (6) alter tablespace apollo_data online; (7) apollo_data.已经恢复 备注:其实datafile和tablespace的恢复步骤是一样的。 3、 模拟controlfile丢失或损坏进行恢复 (1) 丢失controlfile (2) startup nomount; (3) restore controlfile from $BACKUP_CONTROLFILE_PATH; 如果开启CONFIGURE CONTROLFILE AUTOBACKUP ON;就可以 restore controlfile from autobackup; (4) alter database mount; (5) recover database; (6) alter database open resetlog; 4、 模拟spfile丢失或损坏进行恢复 (1) startup nomount; (2) set dbid 1330128391; (3) store spfile from autobackup; (4) shutdown immediate; (5) set dbid 1330128391; (6) startup; 5、 模拟整个database恢复 (1) startup nomount; (2) restore controlfile form autobakcup; (3) alter database mount; (4) restore database; (5) recover database; (6) alter database open resetlogs 6、 模拟redolog file恢复(其实下面操作在sqlplus里面,不在rman执行) (1) shutdown immediate; (2) startup mount; (3) recover database until cancel; (4) alter database resetlog;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值