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. 他们都说JVM能实际使用的内存比-Xmx指定的少?这是为什么呢

    这确实是个挺奇怪的问题,特别是当最常出现的几种解释理由都被排除后,看来JVM并没有耍一些明显的小花招: -Xmx和-Xms是相等的,因此检测结果并不会因为堆内存增加而在运行时有所变化. 通过关闭自适应 ...

  2. 图论算法(一)存图与STL第六弹——vector容器

    图论算法(一)存图 我发现我的博客阅读量贼低,问小伙伴们,ta们都说这些博客太长了QAQ! 今天来个短亿点的(也短不了多少……) 进入正题,图论究竟是什么? 图论就是给你一张图,让你在这张图上进行各种 ...

  3. 土地购买 (斜率优化dp)

    土地购买 (斜率优化dp) 题目描述 农夫 \(John\) 准备扩大他的农场,他正在考虑$ N(1 \leqslant N \leqslant 50,000)$ 块长方形的土地. 每块土地的长宽满足 ...

  4. JavaScript学习系列博客_28_JavaScript 数组去重

    数组去重 var arr = [1,2,3,2,2,1,3,4,2,5]; //去除数组中重复的数字 //获取数组中的每一个元素 for(var i=0 ; i<arr.length ; i++ ...

  5. 【测试技术分享】Liunx常用操作命令集合

    Linux命令 ls 查看文件目录内容 ls -lha  l:详细信息 h:人性化显示 a:查看隐藏目录 ls -目录名  查看指定目录 d rwx rwx rwx d:文件夹 -:文件 rwx:拥有 ...

  6. Mybatis入门(一)------基本概念操作

    Mybatis简介 Mybatis是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以对配置 ...

  7. Mac本软件安装之后打不开的解决办法

    Mac本软件安装之后打不开的解决办法 MacOS系统版本10.15.3 一,安装Axure RP 9 问题:安装之后打不开 提示“Axure RP 9已损坏,无法打开”或“打不开 Axure RP 9 ...

  8. java面试题0001-区分类中重载方法的依据是什么?

    到底是根据什么来区分类中重载的方法? A:不同的返回值类型. B:不同的参数类型. C:不同的访问权限. D:不同的参数名称. 解析: Step1.我们先在DifferentiateReload类中创 ...

  9. 2020重新出发,MySql基础,MySql视图&索引&存储过程&触发器

    @ 目录 视图是什么 视图的优点 1) 定制用户数据,聚焦特定的数据 2) 简化数据操作 3) 提高数据的安全性 4) 共享所需数据 5) 更改数据格式 6) 重用 SQL 语句 MySQL创建视图 ...

  10. go语言字符串的处理与json转换

    1 字符串的处理 可以通过Go标准库中的strings和strconv两个包中的函数进行相应的操作 1 字符串的操作 func Contains(s, substr string) bool 字符串s ...