欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-01-12 18:33:22
一、冷备份1、 冷备份发生在数据库已经正常关闭的情况下,在进行冷备份之前通常要知道需要进行备份文件的名称以及路径复制代码 代码如下:sql>select name f...

一、冷备份
1、 冷备份发生在数据库已经正常关闭的情况下,在进行冷备份之前通常要知道需要进行备份文件的名称以及路径

复制代码 代码如下:

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实例新建监听

上一篇: SVN中的分支

下一篇: ubuntu安装手记