rman 完全恢复

8.1 recover 恢复:

1)归档 : 完全恢复和不完全恢复
2)非归档:只能恢复到最后一次备份状态(还原)

8.2 完全恢复:

----先对数据库做一个备份(如果是archived模式就做热备)

换一种形式,我们将下面的run{}写到linux的脚本中,叫做/u01/oradata/timran11g/myrman.rcv
run {
allocate channel c1 type disk;
allocate channel c2 type disk;
backup database format '/u01/myrman/%d_%s.bak';
}

然后以rman登录时执行这个脚本。语法如下:
rman target / @/u01/oradata/timran11g/myrman.rcv

可以监控RMAN备份,RMAN使用字符串rman 和通道名称填充v$session中client_info列,每个RMAN通道有一行信息, 备份结束后进程信息
消失.也可以使用 set command id to 'XXX'做一个标识,再结合v$session观察通道和进程之间的对应关系。

SQL>
select sid,spid,client_info from v$process p join v$session s on (p.addr=s.paddr)
where client_info like 'rman%';

SID SPID CLIENT_INFO
---------- ------------------------ ----------------------------------------------------------------
113 12992 rman channel=ORA_DISK_1
111 12995 rman channel=ORA_DISK_2

范例1:system表空间损坏,使用EM的DRA恢复

1)在线删除system01.dbf,模拟关键表空间损坏,然后启动数据库,报system01.dbf读写错误

[oracle@timran ~]$ rm /u01/oradata/timran11g/system01.dbf

SQL> startup froce

2) 使用EM恢复...

范例2:恢复表空间(数据库open状态)。因非关键数据文件介质损坏,需要将其表空间恢复到一个新的物理位置。

1)环境
create table scott.t1(id int);
insert into scott.t1 values(1);
commit;

2)模拟users表空间损坏,删除数据文件。

[oracle@timran ~]$ rm /u01/oradata/timran11g/users01.dbf

3) 清除db buffer ,查证访问数据文件失败
SQL> alter system flush buffer_cache;

SQL> alter system checkpoint; //实验中为防备rman登录不正常,可以尝试先做个检查点切换

4)建个目录,假设介质损坏了,更换需要时间,先把数据文件恢复到一个新的目录下(不同的物理位置),

[oracle@timran timran11g]$ mkdir /u01/oradata/timran11g/dir1

5)使用RMAN恢复表空间

RMAN>run{
sql 'alter database datafile 4 offline';
set newname for datafile 4 to '/u01/oradata/timran11g/dir1/users01.dbf';
restore tablespace users;
switch datafile 4;
recover tablespace users;
sql 'alter database datafile 4 online';
}

说明:
set newname for 告诉RMAN还原数据文件的新位置在哪里。这个命令在restore前出现。
switch datafile 更新controlfile,记录这个新位置。这个命令要在recover前出现。

5)验证
SQL> select * from scott.t1;

ID
----------
1

6)待介质更换完成后,可以将表空间迁移回原来位置。

SQL> alter tablespace users offline;

[oracle@timran11g]mv /u01/oradata/timran11g/dir1/users01.dbf /u01/oradata/timran11g

SQL>alter tablespace users rename datafile '/u01/oradata/timran11g/dir1/users01.dbf' to '/u01/oradata/timran11g/users01.dbf';

SQL> alter tablespace users online;

7)再验证

SQL> select * from scott.t1;

范例3:新建表空间(rman备份没有这个表空间),datafile被破坏

1)环境
SQL> create tablespace lx datafile '/u01/oradata/timran11g/lx01.dbf' size 5m;
SQL> create table scott.t2(id int) tablespace lx;
SQL> insert into scott.t2 values (1);
SQL> commit;
SQL> select * from scott.t2;

ID
----------
1

2) 删除t2表所在的数据文件
[oracle@timran ~]$rm /u01/oradata/timran11g/lx01.dbf

3)清除db buffer,查证访问数据文件失败。

SQL> alter system flush buffer_cache;

4)利用rman 恢复数据文件(注意:rman备份里没有lx01.dbf)

RMAN>run {
sql 'alter database datafile 7 offline';
restore datafile 7;
recover datafile 7;
sql 'alter database datafile 7 online';
}

5)验证
SQL> select * from scott.t2;

ID
----------
1

删除lx表空间,为了使数据库和RMAN备份一致

SQL> drop tablespace lx including contents and datafiles;

oracle之三rman 完全恢复的更多相关文章

  1. oracle之三rman 不完全恢复

    rman 不完全恢复 9.1 rman 不完全恢复的三个标准模式:基于time.基于scn和基于sequence: 范例1:恢复过去某个时间点误操作,一般使用基于time或scn. 1)环境:有一套全 ...

  2. oracle之三RMAN概述

    RMAN概述 6.1 rman的定义和功能: 1) Recovery Manager 2)建立备份和恢复的server process,在oracle server上做备份和恢复 3)rman 备份d ...

  3. oracle之三手工完全恢复

    手工完全恢复 3.1 完全恢复:通过备份.归档日志.current log ,将database恢复到failure 前的最后一次commit状态. 3.2 完全恢复的步骤 1)restore: OS ...

  4. oracle之三rman 备份

    rman 备份 7.1 归档方式下rman备份常用语法: 7.1.1 backup 备份 1)备份全库:1.1 RMAN> backup database format='/u01/myrman ...

  5. oracle之三rman 维护

    rman 维护 11.1 rman 使用和维护 11.2 list 命令一览 1)RMAN> list backup; 2)RMAN> list backup of tablespace ...

  6. Oracle 基于 RMAN 的不完全恢复(incomplete recovery by RMAN)

    Oracle 数据库可以实现数据库不完全恢复与完全恢复.完全恢复是将数据库恢复到最新时刻,也就是无损恢复,保证数据库无丢失的恢复.而不完全恢复则是根据需要特意将数据库恢复到某个过去的特定时间点或特定的 ...

  7. Oracle—RMAN完全恢复

    一.RMAN完全恢复的相关概念 1.在RMAN完全恢复中主要使用两个命令,一个是restore,另一个是recover. 2.可以在三个级别恢复,数据库,表空间,数据文件. 3.RMAN中应对于各种情 ...

  8. oracle数据库rman备份计划及恢复

    1.rman完全恢复的前提条件:历史的datafile,controlfile和spfile备份,加上完整的archivelog和完好的redolog. 2.rman备份脚本: a.RMAN 0级备份 ...

  9. Oracle单机Rman笔记[5]---脱机异地还原

    脱机异地还原(安装一个原环境相同的linux,并安装数据库,注意不要配置安装实例) .检查/home/oracle下的.bashrc .bash_profile内容是否与原环境一致(具体看情况而定), ...

随机推荐

  1. Golang gRPC学习(04): Deadlines超时限制

    为什么要使用Deadlines 当我们使用gRPC时,gRPC库关系的是连接,序列化,反序列化和超时执行.Deadlines 允许gRPC客户端设置自己等待多长时间来完成rpc操作,直到出现这个错误 ...

  2. three.js 制作逻辑转体游戏(上)

    今天郭先生又出来制作游戏了,最近有小伙伴要做一个逻辑转体小游戏,我怎么能不先来试试呢.玩法可以看上面的连接,下面附几张图.线案例请点击博客原文. 游戏规则不懂得可以看自行百度哈,其实玩起来还挺有难度的 ...

  3. Banner信息收集

    一.什么是Banner Banner信息,欢迎语,在banner信息中可以得到软件开发商,软件名称.版本.服务类型等信息,通过这些信息可以使用某些工具直接去使用相对应的exp去攻击. 前提条件:需要和 ...

  4. chained get value from nested json

    static getValueByKey(o, p, defaultValue = false) { return p.split('.').reduce((r, k) => { if (typ ...

  5. neutron plugin 与 extension 编写流程

    原文链接:neutron plugin 与 extension 编写流程 参考: 怎样写 OpenStack Neutron 的 Plugin (一)怎样写 OpenStack Neutron 的 P ...

  6. Hadoop的SecondaryNameNode的作用是什么?

    为节省篇幅,将SecondaryNameNode简称SNN,NameNode简称NN. NN与fsimage.edits文件 NN负责管理HDFS中所有的元数据,包括但不限于文件/目录结构.文件权限. ...

  7. js大数字转换,将大额数字转换为万、千万、亿等

    代码 /** * 大数字转换,将大额数字转换为万.千万.亿等 * @param value 数字值 */ export function bigNumberTransform (value) { co ...

  8. Java面试题(RabbitMQ篇)

    RabbitMQ 135. rabbitmq 的使用场景有哪些? ①. 跨系统的异步通信,所有需要异步交互的地方都可以使用消息队列.就像我们除了打电话(同步)以外,还需要发短信,发电子邮件(异步)的通 ...

  9. Netty源码分析之ByteBuf(一)—ByteBuf中API及类型概述

    ByteBuf是Netty中主要的数据容器与操作工具,也是Netty内存管理优化的具体实现,本章我们先从整体上对ByteBuf进行一个概述: AbstractByteBuf是整个ByteBuf的框架类 ...

  10. 领导给了一堆无序杂乱的数据,我写了个Python自动化脚本

    这个问题算是群友答疑.如果说同事或者老板给你一堆这样的数据,你估计会抓狂,该怎么处理呢? 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手. ...