oracle冷备份恢复和oracle异机恢复使用方法

一、冷备份

1、 冷备份发生在数据库已经正常关闭的情况下,在进行冷备份之前通常要知道需要进行备份文件名称以及路径
代码如下:
301">
sql>select name from v$datefile;
sql>select name from v$controlfile;
sql>select member from v$logfile;

2、冷备份所需备份的文件包括以下几种:
所有数据文件、所有控制文件、所有联机REDO LOG 文件
3、冷备份的步骤
①正常关闭要备份的实例(instance)
②拷贝所有重要文件到备份目录下
③完成备份后启动数据库
4、用冷备份进行数据库恢复
无归档模式:将备份文件拷贝回原来的目录即可,然后启动数据库
归档模式:
①将数据文件、控制文件拷贝回原来目录
sql>startup mount;
sql>recover database using backup controlfile;
③将相应的归档日志和联机日志拖到CMD命令窗口进行跑日志。
sql>alter database open resetlogs;

二、异机恢复冷备份恢复方式

A、不创建实例:(源机上的数据库名字为orcl)
①在目标机上的oradata目录下建立orcl文件夹,拷贝源机的所有data文件和联机redo文件到此目录下。
②在目标机上的admin目录下建立orcl文件夹,然后在orcl里面再建立adump、bdump、cdump、udump、dpdump、pfile六个文件
③把源机的密码文件拷贝到目标机的database目录下。
④使用oradim命令在cmd下oradim -new -sid orcl 表示建立一个服务,sid为orcl(最好名字和源机备份的数据库名字一致,就不需要重建密码文件
⑤拷贝源机的pfile到目标机的一个目录下,修改pfile里面相关文件的路径,然后通过sql>create spfile from pfile=‘文件路径'来创建参数文件
⑥重建控制文件命令:sql>alter database backup controlfile to trace;然后会在udump文件夹下产生一个追踪文件,打开文件找到如下一段,复制到文本中,修改相应路径然后保存为:createctl.sql文件sql脚本文件),复制到目标机上。
注意:sql>alter database backup controlfile to trace as 'aa.txt';linux系统中会在dbs目录下建立
代码如下:
STARTUP NOMOUNT
CREATE CONTROLFILE REUSE DATABASE "ORCL" RESETLOGS ARCHIVELOG
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 292
LOGFILE
GROUP 1 'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO01.LOG' SIZE 50M,
GROUP 2 'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO02.LOG' SIZE 50M,
GROUP 3 'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\REDO03.LOG' SIZE 50M
-- STANDBY LOGFILE
DATAFILE
'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSTEM01.DBF',
'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\UNDOTBS01.DBF',
'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\SYSAUX01.DBF',
'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\USERS01.DBF',
'C:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\BANK_DATA02.DBF'
CHARACTER SET ZHS16GBK;

⑦ c:\>set ORACLE_SID=orcl
c:\>sqlplus "/as sysdba"
sql>create spfile from pfile='c:\pfile.txt';
sql>@c:\createctl.sql;
sql>shutdown immediate;
sql>startup;
sql>alter database open resetlogs;
⑧在network\admin下的tnsnames.ora中添加如下片段
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = orcl)
)
)


⑨用net configuration为orcl实例新建监听

B、创建实例(实例SID与源机数据库SID一致)
删除目标机的oradata\orcl底下的所有文件,把源机的所有data文件、redo文件拷贝到此目录下
删除目标机的密码文件,拷贝源机密码文件到目标机下。
③在源机上重建目标机的控制文件sql>alter database backup controlfile to trace;然后会在udump文件夹下产生一个追踪文件,打开文件找到上面那段,复制到文本中,修改相应路径然后保存为:createctl.sql文件sql脚本文件),复制到目标机上。

代码如下:
c:\>sqlplus "/as sysdba"
sql>@c:\createctl.sql;
sql>shutdown immediate;
sql>startup;
sql>alter database open resetlogs;

⑤在network\admin下的tnsnames.ora中添加如下片段
代码如下:
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = orcl)
)
)

⑥用net configuration为orcl实例新建监听

相关文章

数据库版本:11.2.0.4 RAC(1)问题现象从EM里面可以看到,在23号早上8:45~8:55时,数据库等待会话暴增...
(一)问题背景最近在对一个大约200万行数据的表查看执行计划时,发现存在异常,理论上应该返回100多万...
(一)删除备份--DELETE命令用于删除RMAN备份记录及相应的物理文件。当使用RMAN执行备份操作时,会在RM...
(1)DRA介绍 数据恢复顾问(Data Recovery Advise)是一个诊断和修复数据库的工具,DRA能够修复数据文...
RMAN(Recovery Manager)是Oracle恢复管理器的简称,是集数据库备份(backup)、修复(restore)和恢复...
(1)备份对象 可以使用RMAN进行的备份对象如下: --整个数据库:备份所有的数据文件和控制文件; --数...