eygle.com   eygle.com
eygle.com  
 

« Statspack专题 | Blog首页 | Oracle X$ table 参考手册 »

使用热备份进行分时恢复

作者:eygle |【转载时请以超链接形式标明文章和作者信息及本声明
链接:
----怎样通过归档逐步恢复以缩短数据迁移时间

很多时候你可能遇到这样的情况:
一个大型数据库的迁移,但是只有很少的停机时间,这看起来充满困难。可是我们可以通过各种方法来缩短停机时间.

本例适用于同平台、同版本数据库迁移.

在此情况下,我们可以通过一个热备份,应用归档恢复数据库到一个一致的状态,此时数据库可以被只读(read only)打开。
之后我们可以继续应用归档进行恢复,最后只需要短时停机,复制原数据库中的在线日志及归档日志、控制文件到新库中,进行恢复,此时
只需要极短时间即可完成恢复。

此方法可以极大缩短割接时间。以下是一个示范步骤,供参考:

1.启动数据库

查询归档情况

SQL> select name from v$archived_log;

NAME
--------------------------------------------------------------------------------
E:\ORACLE\ORADATA\EYGLE\REDO01.LOG
E:\ORACLE\ORADATA\EYGLE\REDO02.LOG
E:\ORACLE\ORADATA\EYGLE\REDO03.LOG
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00001.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00002.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00003.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00004.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00005.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00006.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00001.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00002.001

NAME
--------------------------------------------------------------------------------
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00003.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00004.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00005.001
E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00006.001

已选择15行。
                      

归档当前日志

 

SQL> alter system switch logfile;

系统已更改。

 

 

2.备份数据库

备份脚本:

 

alter tablespace system begin backup;
host copy E:\ORACLE\ORADATA\EYGLE\SYSTEM01.DBF e:\oracle\orabak\SYSTEM01.DBF
alter tablespace system end backup;
alter tablespace undotbs1 begin backup;
host copy E:\ORACLE\ORADATA\EYGLE\UNDOTBS01.DBF e:\oracle\orabak\UNDOTBS01.DBF
alter tablespace undotbs1 end backup;
alter tablespace eygle begin backup;
host copy E:\ORACLE\ORADATA\EYGLE\EYGLE01.DBF  e:\oracle\orabak\EYGLE01.DBF 
alter tablespace eygle end backup;
      

执行备份:

 

SQL> @e:\a.sql

表空间已更改。

已复制         1 个文件。


表空间已更改。


表空间已更改。

已复制         1 个文件。


表空间已更改。


表空间已更改。

已复制         1 个文件。


表空间已更改。


数据库已更改。      

3.更改数据并归档部分日志

SQL> insert into eygle.test select *from eygle.test;

已创建224行。

SQL> commit;

提交完成。

SQL> alter system switch logfile;

系统已更改。

SQL> insert into eygle.test select *from eygle.test;

已创建448行。

SQL> commit;

提交完成。

SQL> alter system switch logfile;

系统已更改。

SQL> insert into eygle.test select *from eygle.test;

已创建896行。

SQL> commit;

提交完成。

SQL> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。

 

4.执行恢复
恢复备份的数据文件,启动数据库
使用当前日志及控制文件

SQL> startup mount;
ORACLE 例程已经启动。

Total System Global Area   47259136 bytes
Fixed Size                   454144 bytes
Variable Size              29360128 bytes
Database Buffers           16777216 bytes
Redo Buffers                 667648 bytes
数据库装载完毕。
SQL> recover database using backup controlfile until cancel;
ORA-00279: 更改 197282 (在 11/13/2004 23:30:48 生成) 对于线程 1 是必需的
ORA-00289: 建议: E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00008.001
ORA-00280: 更改 197282 对于线程 1 是按序列 # 8 进行的


指定日志: {=suggested | filename | AUTO | CANCEL}

ORA-00279: 更改 197393 (在 11/13/2004 23:32:22 生成) 对于线程 1 是必需的
ORA-00289: 建议: E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00009.001
ORA-00280: 更改 197393 对于线程 1 是按序列 # 9 进行的
ORA-00278: 此恢复不再需要日志文件
'E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00008.001'


指定日志: {=suggested | filename | AUTO | CANCEL}
cancel
介质恢复已取消。
SQL> alter database open read only;

数据库已更改。

SQL> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup mount;
ORACLE 例程已经启动。

Total System Global Area   47259136 bytes
Fixed Size                   454144 bytes
Variable Size              29360128 bytes
Database Buffers           16777216 bytes
Redo Buffers                 667648 bytes
数据库装载完毕。
SQL> recover database using backup controlfile until cancel;
ORA-00279: 更改 197393 (在 11/13/2004 23:32:22 生成) 对于线程 1 是必需的
ORA-00289: 建议: E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00009.001
ORA-00280: 更改 197393 对于线程 1 是按序列 # 9 进行的


指定日志: {=suggested | filename | AUTO | CANCEL}

ORA-00279: 更改 197423 (在 11/13/2004 23:32:51 生成) 对于线程 1 是必需的
ORA-00289: 建议: E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00010.001
ORA-00280: 更改 197423 对于线程 1 是按序列 # 10 进行的
ORA-00278: 此恢复不再需要日志文件
'E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00009.001'


指定日志: {=suggested | filename | AUTO | CANCEL}
cancel
介质恢复已取消。
SQL> alter database open read only;

数据库已更改。

SQL> shutdown immediate;
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup mount;
ORACLE 例程已经启动。

Total System Global Area   47259136 bytes
Fixed Size                   454144 bytes
Variable Size              29360128 bytes
Database Buffers           16777216 bytes
Redo Buffers                 667648 bytes
数据库装载完毕。

SQL> recover database using backup controlfile until cancel;
ORA-00279: 更改 197423 (在 11/13/2004 23:32:51 生成) 对于线程 1 是必需的
ORA-00289: 建议: E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00010.001
ORA-00280: 更改 197423 对于线程 1 是按序列 # 10 进行的


指定日志: {=suggested | filename | AUTO | CANCEL}
E:\Oracle\oradata\eygle\REDO01.LOG
ORA-00310: 存档日志包含序列 9;要求序列 10
ORA-00334: 归档日志: 'E:\ORACLE\ORADATA\EYGLE\REDO01.LOG'


SQL> recover database using backup controlfile until cancel;
ORA-00279: 更改 197423 (在 11/13/2004 23:32:51 生成) 对于线程 1 是必需的
ORA-00289: 建议: E:\ORACLE\ORADATA\EYGLE\ARCHIVE\ARC00010.001
ORA-00280: 更改 197423 对于线程 1 是按序列 # 10 进行的


指定日志: {=suggested | filename | AUTO | CANCEL}
E:\Oracle\oradata\eygle\REDO02.LOG
已应用的日志。
完成介质恢复。
SQL> alter database open;
alter database open
*
ERROR 位于第 1 行:
ORA-01589: 要打开数据库则必须使用 RESETLOGS 或 NORESETLOGS 选项

SQL> alter database open resetlogs;

数据库已更改。

SQL>

 

注意中间的部分,read only打开不影响数据库进一步的恢复.也就是说恢复可以分步进行。

 


历史上的今天...
      >> 2008-11-15文章:
      >> 2006-11-15文章:
      >> 2005-11-15文章:
             NetAPP iSCSI性能测试
             iSCSI节点名称定义及其他
------
这篇 【使用热备份进行分时恢复】来自 eygle.com | CSDN网摘| del.icio.us|Google订阅 | 鲜果订阅 | 抓虾订阅

By eygle on 2004-11-15 11:36 | Comments (5) | Posted to Backup&Recovery | Edit |Pageviews:

相关文章 随机文章
  • Oracle Database 11g回滚段命名的变化
  • ORA-600 kcbgtcr_13 未解决之问题记录
  • 圣诞超级复杂困难之Oracle数据库大恢复
  • ORA-00704 与 bootstrap 错误
  • 这是一个Oracle普及的时代
  • 悼念逝者 更改 Eygle.Com 首页颜色
    推荐电影《Juno》-朱诺
    使用SQL_TRACE进行数据库诊断
    Oracle10g EM乱码之快速解决
    Oracle数据字典说明
    搜索本站:

    留言 (5)

    这个例子应该是个完全恢复,为什么不能用alter database open打开,而只能用alter database open resetlogs呢?

    Posted by: liuchenyun at January 17, 2007 10:03 AM

    因为用了
    recover database using backup controlfile until cancel;
    这个选项。

    Posted by: eygle at January 17, 2007 10:59 AM

    对的对的,真是不仔细,谢谢

    Posted by: liuchenyun at January 17, 2007 4:02 PM

    看不明白那里节约 还请哪位给解释一下 谢谢!

    Posted by: zcykkk at September 18, 2007 8:50 PM

    这个做法有一个关键的地方,就是recover database using backup controlfile until cancel;中的using backup controlfile~! 注意盖先生实验中说了“4.执行恢复
    恢复备份的数据文件,启动数据库
    使用当前日志及控制文件”既然是用了当前的控制文件,为什么要using backup controlfile?! 这个是能read only打开的关键~ 因为使用了这个,会导致oracle在recover时认为控制文件是旧的,这样recover就会更新控制文件中的所有datafile的checkpoint_change#纪录,只有这样,才能保证alter database open read only前,数据库中每个数据文件头部纪录的checkpoint_change#和controlfile中记录的是一致的,只有这样才能够read only打开数据库,否则,oracle会认为数据库不一致,不允许read only打开。

    Posted by: zergduan at February 26, 2009 2:05 PM

    发表留言:



    Remember Me?
    (输入验证码后方可评论,谢谢支持)



    CopyRight © 2004 eygle.com, All rights reserved.