热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

rman数据库恢复;关键/非关键文件、影像副本、控制文件、还原点

执行完全恢复:在ARCHIVELOG模式下丢失了系统关键数据文件:如果某个数据文件丢失或损坏,且该文件属于SYSTEM或UNDO表空间,请执行以下步骤:1.实例可能会也可能不会自动关闭。2.如果未自动关闭,请使用SHUTDOWNABORT关闭实例。3.装载数据库

执行完全恢复:在 ARCHIVELOG 模式下 丢失了系统关键数据文件: 如果某个数据文件丢失或损坏,且该文件属于 SYSTEM 或 UNDO 表空间,请执行以下步骤: 1. 实例可能会也可能不会自动关闭。 2.如果未自动关闭,请使用 SHUTDOWN ABORT 关闭实例。 3. 装载数据库

执行完全恢复:在 ARCHIVELOG 模式下 丢失了系统关键数据文件:

如果某个数据文件丢失或损坏,且该文件属于 SYSTEM 或 UNDO 表空间,请执行以下步骤:

1.
实例可能会也可能不会自动关闭。
2.如果未自动关闭,请使用 SHUTDOWN ABORT 关闭实例。
3.
装载数据库。
4.
还原并恢复缺失的数据文件。

5.打开数据库。

1.归档模式丢失非关键数据文件 完全恢复

第一种方法:

shutdown abort;

startup mount;

alter database create datafile '/home/oracle/test.dbf' as '/home/oracle/test.dbf';

recover datafile;

第二种方法:

create tablespace test datafile '/home/oracle/test.dbf' size 10m;

rman target /

backup datafile 5;

rm test.dbf

sq> alter database datafile 5 offline;

restore datafile 5;

recover datafile 5;

sq> alter database datafile 5 online;

select FILE#,STATUS from v$datafile;

2. 归档模式丢失关键数据文件 完全恢复

利用备份,同上第二种方法。

--------------------------------------------------------------------------------------------------------------
恢复映像副本:
RMAN> recover copy of database with tag 'daily_inc';

RMAN> backup incremental level 1 for recover of copy
with tag 'daily_inc' database;

RECOVER BACKUP
第 1 天 无 创建映像副本
第 2 天 无 创建 1 级增量备份
第 3 天和以后 根据增量备份恢复副本 创建 1 级增量备份


恢复映像副本:示例
如果每天都运行以上命令,则可以随时获得所有数据库数据文件的连续更新的映像副本。
图表显示了每次运行所发生的操作。请注意,这种算法需要一段准备期间;到第 3 天后策略才会起作用。

第 1 天
RECOVER 命令没有执行任何操作。尚不存在要恢复的映像副本。BACKUP 命令可用于创建映像副本。

第 2 天
RECOVER 命令仍没有执行任何操作。因为尚不存在增量备份。由于已在第 1 天创建了基准映像副本,BACKUP 命令会创建增量备份。
第 3 天
RECOVER 命令将增量备份中的更改应用于映像副本。BACKUP 命令将执行另一个增量备份,该备份将在第 4 天用于恢复映像副本,依此进行循环。

执行到映像副本的快速切换
执行以下步骤

可以使用数据文件的映像副本进行快速恢复:

1.使数据文件脱机。
2.使用 SWITCH TO ...COPY 命令指向这些文件的映像副本。

3.恢复数据文件。
4.使数据文件联机。

此时,数据库是可用的,且数据文件已恢复。但是,如果您希望将数据文件放回其原始位置,请继续执行以下步骤:

5.使用 BACKUP AS COPY 命令在原始位置创建数据文件的映像副本。

6.使数据文件脱机。

7.使用 SWITCH TO COPY 命令切换到在步骤 5 中创建的副本。

8.恢复数据文件。

9.使数据文件联机。
可以使用此命令来恢复数据文件、表空间、临时文件或整个数据库。切换到的目标文件必须为映像副本。

3. 映像副本的快速切换

backup as copy datafile 6;

rm a.dbf

sql:alter database datafile 6 offline;

rman >switch datafile '/home/oracle/test.dbf' to copy;

recover datafile 6;

--回复后数据文件的路径和名称为 '/home/oracle/test.dbf';

alter database datafile 4 online;

select FILE#,STATUS from v$datafile;

select file_name from dba_data_files;

backup as copy datafile 4 format '/u01/app/oracle/oradata/orcln/users01.dbf';

alter database datafile 4 offline;

switch datafile ' /home/oracle/backup/db_data_D-ORCL_I-4115975543_TS-TEST_FNO-6_38otbf5q.bak' to copy;

switch datafile 4 to copy;

recover datafile 4;

alter database datafile 4 online;

select file_name from dba_data_files;

-----------------------------------------------------------------------------------------------------------------

4. set newname 改名字

backup as copy datafile 6;

list copy of datafile 6;

select FILE#,STATUS from v$datafile;

run{

allocate channel c1 device type disk;

sql "alter database datafile 6 offline";

set newname for datafile '/home/oracle/test.dbf' to '/home/oracle/test_new.dbf';

restore datafile 6;

switch datafile all;

recover datafile 6;

sql "alter database datafile 6 online";

}
--------------------------------------------------------------------------------------------------------------
从自动备份还原控制文件:

RMAN> STARTUP NOMOUNT;

RMAN> RESTORE CONTROLFILE FROM AUTOBACKUP;

RMAN> ALTER DATABASE MOUNT;

RMAN> RECOVER DATABASE;

RMAN> ALTER DATABASE OPEN RESETLOGS;

7. 丢失控制文件,参数文件 --数据库必须在nomount状态

查看文件信息:

SQL>select name from v$controlfile;

SQL>show parameter spfile;

SQL> select name from v$datafile;

配置控制文件自动备份恢复控制文件

rman target /

connected to target database: ORCL (DBID=1353286769)

RMAN>show all;

RMAN>CONFIGURE CONTROLFILE AUTOBACKUP ON;

数据库全备份:

RMAN>backup as compressed backupset full database;

删除,参数文件,控制文件,数据文件

rm /opt/oracle/oradata/orcl/control01.ctl

rm /opt/oracle/flash_recovery_area/orcl/control02.ctl

rm /opt/oracle/oradata/orcl/control03.ctl

rm /opt/oracle/product/11.2.2/dbs/spfileorcl.ora

rm /opt/oracle/oradata/orcl/system01.dbf

rm /opt/oracle/oradata/orcl/sysaux01.dbf

rm /opt/oracle/oradata/orcl/undotbs01.dbf

rm /opt/oracle/oradata/orcl/users01.dbf

rm /home/oracle/tbs_ctl01.dbf

rman target /

RMAN> set dbid 1353286769 --如果备份在

startup nomount --虽然没有参数文件但是也可以启动实例

恢复参数文件:

restore spfile from '/data/backup/ctl_c-1353286769-20131102-04.bak';

/* 从快速恢复区恢复参数文件:

run {

restore spfile from autobackup

recovery area = 'flash recovery area destination'

db_name = 'db_name';

}

*/

查看是否有需要改的参数:主要看文件位置

SQL> create pfile from spfile;

恢复控制文件:

restore controlfile to '/opt/oracle/oradata/orcl/control01.ctl' from '/data/backup/ctl_c-1353286769-20131102-04.bak';

恢复数据文件:

RMAN> shutdown immediate

RMAN> startup mount

RMAN> restore database;

RMAN> recover database;

RMAN> alter database open;

RMAN-00571: ===========================================================

RMAN-00569: =============== ERROR MESSAGE STACK FOLLOWS ===============

RMAN-00571: ===========================================================

RMAN-03002: failure of alter db command at 11/02/2013 12:10:46

ORA-01589: must use RESETLOGS or NORESETLOGS option for database open

RMAN> alter database open resetlogs;
--------------------------------------------------------------------------------------------------------------
使用增量备份恢复处于 NOARCHIVELOG 模式的数据库:

STARTUP FORCE NOMOUNT;

RESTORE CONTROLFILE;

ALTER DATABASE MOUNT;

RESTORE DATABASE;

RECOVER DATABASE NOREDO;

ALTER DATABASE OPEN RESETLOGS;

8. 使用增量备份恢复处于NOARCHIVELOG 模式的数据库

1) 撤销数据库archivelog模式

SQL>shutdown immediate;

SQL>startup mount;

SQL>alter database noarchivelog;

SQL>alter database open;

SQL>archive log list;

2) 创建测试用表及数据

conn zhuxy/zhuxy

create table c (id number);

insert into c values(1);

commit;

3) 在noarchivelog模式下,0级备份

RMAN> run{

shutdown immediate;

startup mount;

backup as backupset incremental level 0 database;

alter database open;

}

4) 在noarchivelog模式下,1级备份

insert into c values(2);

commit;

RMAN> run{

shutdown immediate;

startup mount;

backup as backupset incremental level 1 database;

alter database open;

}

6) 删除所有日志文件, 某些数据文件

7) 执行恢复

rman target /

RMAN>startup mount;

--执行全库的还原

RMAN> restore database;

-- 使用noredo子句进行恢复

RMAN> recover database noredo;

--恢复完成,resetlogs方式打开数据库,完成所有文件丢失的恢复

RMAN> alter database open resetlogs;

8)验证在测试前(增量备份前)插入的数据

select * from c;

6.非归档丢失文件

不完全恢复: SCN, 时间,还原点,或日志序列号

1确定目标还原点:SCN、时间、还原点或日志序列号。

2设置 NLS 环境变量。

3装载数据库。

4使用 SET UNTIL、RESTORE 和 RECOVER 命令准备并运行 RUN 块。

5用 RESETLOGS 打开数据库。

-----不完全恢复之--基于时间的恢复

1) 准备环境:RMAN全库备份

RMAN> backup as compressed backupset full database;

2) 准备环境:测试表及数据

alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';

create table d (c date);

insert into d values(sysdate);

commit;

create table ff (c date);

insert into ff values(sysdate);

commit;

启动到mount模式,进行基于时间的恢复

shutdown immediate;

startup mount;

run

{sql 'alter session set nls_date_format="yyyy-mm-dd hh24:mi:ss"';

set until time = ' 2014-03-30 00:39:34';

restore database;

recover database;

alter database open resetlogs;

}

时间也可以这么写:

set until time="to_date('2013-11-01 15:29:34','yyyy-mm-dd hh24:mi:ss')";

-----还原点:

select count(*) from copy_emp;

创建还原点:

create restore point before_delete;

delete from copy_emp where ID >=10;

commit;

alter table copy_emp enable row movement;

flashback table copy_emp to restore point b;

--------------------------------------------------------------------------------------------------------------
将数据库还原到新主机:

为了还原数据库,请在还原主机上执行以下步骤:

1.配置 ORACLE_SID 环境变量。

2.启动 RMAN 并在 NOCATALOG 模式下连接到目标实例。

3.设置数据库标识符 (DBID)。

4.在 NOMOUNT 模式下启动实例。
5.
从备份集中还原服务器参数文件。

6.关闭实例。
7.
编辑还原的初始化参数文件。
8.
在 NOMOUNT 模式下启动实例
9.创建 RUN 块以执行下列任务:

--还原控制文件
--
装载数据库

10.创建 RMAN 恢复脚本以还原和恢复数据库。

11.执行 RMAN 脚本。

12.使用 RESETLOGS 选项打开数据库。

9 利用备份将数据库还原到新主机:目标库需要有oracle软件

1)准备工作

源库数据库全备及控制文件自动备份,当然也包括参数文件

RMAN> backup as backupset database;

2)拷贝RMAN备份文件到目标库

可以用scp

3)配置目标库

目标库设置环境变量

export ORACLE_SID=new_orcl

启动rman到nomount状态,设置dbid(即源库dbid)

$ rman target /

RMAN> set dbid 1357901988

RMAN> startup nomount; --没有参数文件,会报错,但是可以启动实例

4)恢复参数文件

RMAN> restore spfile to pfile '' from '';

编辑pfile参数文件:文件位置,数据库实例名..,创建相应的目录

5) 启动数据库到nomount模式

SQL> create spfile from pfile;

SQL> startup nomount;

6)还原控制文件

$ rman target /

RMAN> restore controlfile to '' from '';

RMAN> alter database mount;

7) 还原数据文件

run{

SET NEWNAME FOR DATAFILE 1 TO '/u01/app/oracle/oradata/orcl/system01.dbf';

SET NEWNAME FOR DATAFILE 2 TO '/u01/app/oracle/oradata/orcl/sysaux01.dbf';

SET NEWNAME FOR DATAFILE 3 TO '/u01/app/oracle/oradata/orcl/undotbs01.dbf';

SET NEWNAME FOR DATAFILE 4 TO '/u01/app/oracle/oradata/orcl/users01.dbf';

SET NEWNAME FOR DATAFILE 5 TO '/u01/app/oracle/oradata/orcl/example01.dbf';

SET NEWNAME FOR DATAFILE 6 TO '/u01/app/oracle/oradata/orcl/test.dbf';

RESTORE DATABASE;

SWITCH DATAFILE ALL;

RECOVER DATABASE;}

--rename日志文件

run{

SQL "ALTER DATABASE RENAME FILE ''/u01/app/oracle/oradata/ENMOEDU/redo01.log'' TO

''/u01/app/oracle/oradata/orcl/redo01.log'' ";

SQL "ALTER DATABASE RENAME FILE ''/u01/app/oracle/oradata/ENMOEDU/redo02.log'' TO

''/u01/app/oracle/oradata/orcl/redo02.log'' ";

SQL "ALTER DATABASE RENAME FILE ''/u01/app/oracle/oradata/ENMOEDU/redo03.log'' TO

''/u01/app/oracle/oradata/orcl/redo03.log'' ";

}

RMAN> alter database open resetlogs;

8)临时文件位置不对

SQL> select file_name from dba_temp_files;

SQL>create temporary tablespace tempa tempfile

'/u01/app/oracle/oradata/orcl/tempa01.dbf' size 10m reuse autoextend on maxsize 200m;

SQL>alter database default temporary tablespace tempa;

SQL>drop tablespace temp;

SQL>select file_name from dba_temp_files;

注:这个测试改变了实例名
--------------------------------------------------------------------------------------------------------------
执行灾难恢复 :

灾难意味着丢失了整个目标数据库、恢复目录数据库、所有当前控制文件、所有联机重做日志文件和所有参数文件。

灾难恢复包括还原和恢复目标数据库。

备份集的最低要求:

1.数据文件的备份
2.
相应的归档重做日志文件
3.
至少一个控制文件自动备份

基本过程:
1.
还原服务器参数文件的自动备份。

2.启动目标数据库实例。

3.从自动备份还原控制文件。

4.装载数据库。

5.还原数据文件。

6.恢复数据文件。

7.使用 RESETLOGS 选项打开数据库。


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文探讨了Hive中内部表和外部表的区别及其在HDFS上的路径映射,详细解释了两者的创建、加载及删除操作,并提供了查看表详细信息的方法。通过对比这两种表类型,帮助读者理解如何更好地管理和保护数据。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 使用Python在SAE上开发新浪微博应用的初步探索
    最近重新审视了新浪云平台(SAE)提供的服务,发现其已支持Python开发。本文将详细介绍如何利用Django框架构建一个简单的新浪微博应用,并分享开发过程中的关键步骤。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文详细介绍了 MySQL 中 LAST_INSERT_ID() 函数的使用方法及其工作原理,包括如何获取最后一个插入记录的自增 ID、多行插入时的行为以及在不同客户端环境下的表现。 ... [详细]
  • 本文介绍如何在 FireDAC 环境下实现 FDMEMTable 字段的自动获取,为开发人员提供便捷的数据处理方式。 ... [详细]
author-avatar
xiao666tian760
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有