赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

Oracle的Archive Log模式下的恢复工作

发布时间:2006.12.13 04:46     来源:赛迪网技术社区    作者:sdhanyun


学习并测试了一下Oracle数据库在开启Archive Log模式下的恢复。

系统是Win2K Server+Oracle 8.1.7。参考了Chinaunix.net和ITPub.com网站相关资料.在此感谢给我的帮助。注意,养成一个好的习惯非常重要.在开始恢复之前,以及恢复完成后,都要做一个系统全备份。

首先,要开启Archive Log归档日志模式。

1. 关闭数据库

2. 修改initSID.ora文件.这个文件通常在$ORACLE_HOME/admin/$ORACLE_SID目录下或是在$ORACLE_HOME/database目录下。

 

 
  log_archive_start = true
  log_archive_dest_1 = "location=F:oraclearchive"
  log_archive_format = "ORA_%S.arc"
  

注意通常Windows版和Unix/Linux版的一些参数写法有差异,请参照各自版本的技术文档。

3. 启动数据库到mount状态

startup mount

这样加载了数据库文件,但是不打开数据库。

4. 检查当前的Archive Log归档日志模式

archive log list

显示的信息是:

 

 
  Database log mode       No Archive Mode
  Automatic archival       Disabled
  

这时用下面的命令开启数据库的Archive Log模式

 

 
  alter database archivelog
  

再次用"archive log list"显示信息,应该是:

 

 
  Database log mode       Archive Mode
  Automatic archival       Enabled
  

再用命令alter database open来打开数据库。上面的工作完了以后,然后,我们可以来进行测试了。在测试之前,我们来熟悉一下这个归档日志Archive Log是什么样的。通过Sqlplus或Svrmgrl以sysdba身份连接到数据库,执行"alter system switch logfile;"在我们指定的F:oraclearchive目录下就可以看到归档日志了。文件名是我们指定的形同"ORA_0379.arc",其中0379是Oracle自动取的序号.在我们做。最后,我们要来测试归档模式下的备份恢复有什么不一样。

在非归档模式下,我们一般每天做一次数据库备份(冷备份和热备份的差别仅在于备份时数据库是关闭的还是开启的).这样,我们就拥有了每天一个的备份点,换句话说,我们可以在数据库崩溃的情况下,通过备份介质,将数据库恢复到某一个备份点上。但是显而易见,这样的备份和恢复是不完全的,我们对于两个备份点之间的数据是无法恢复的。

而在开启了归档模式的情况下,情况不一样了.所有系统的REDO_log重做日志中提交的操作,均会在重做日志重复利用前被保存为归档日志保存下来,也就是说,所有用户对于数据库的每一个操作都被记录在案.这样.在维持我们原先的数据库备份计划的情况下,除了每天一个备份点之外,我们还拥有了没两个备份点之间的所有历史操作记录。

这样,结合每天的数据库备份和归档日志以及在线重做日志,我们可以将数据库精确恢复到数据库崩溃前的那一时刻, 不会有数据丢失的情况发生。当然,这样的前提是,数据库备份和归档日志不能同时损坏或丢失。

我们假设的环境是:

假设有3个硬盘, C, D, E,系统在C盘, 数据文件在D盘,归档日志在E盘.控制文件,在线重做日志都有3组并复用,放在C盘,D盘和E盘.

现在的情况是我们保留有所有的归档日志,保留有5天前的备份磁带(很不巧,由于种种原因,近5天的备份都没有成功,不过幸运的是,在此期间系统及软件配置都没有更改).

硬盘D突然损坏了,数据库崩溃了,所有人都无法连接到数据库.

在本例中,我们只考虑了数据文件损坏, 假设所有的控制文件,重做日志都正常。我们现在要开始恢复工作了。在联系了硬件供应商后,我们的新硬盘到了,安装上后,通过5天前的备份磁带,恢复D盘上所有的文件。通过Svrmgrl或Sqlplus以system用户登录到Oracle。打开数据库到mount状态,"startup mount",这时,Oracle会提示数据库文件损坏,需要修复。根据提示的文件,输入命令"recover datafile 'D:OracleData01.dbf';Oracle将自动寻找所需要的归档日志和当前的Redo_log来恢复数据文件,我们只需要在每一个提示信息后按回车键确定应用所显示的归档日志文件.恢复完成后,Oracle将有提示信息。恢复完成后,可以尝试用命令"alter database open"来打开数据库,如果还是有数据文件损坏,Oracle将再次提示需要修复.只需要重复上面两步操作.

重复操作,直至所有的数据文件都恢复.用命令"alter database open"来打开数据库。这样,我们就基本完成了归档模式开启的情况下的数据库恢复工作,在这种模式下,数据库可以恢复到任一时刻(可以在应用归档日志文件恢复时取消以中断恢复过程).而且,即便因意外而导致我们的每日数据库备份没有成功执行时,仍然可以通过几天前的冷/热备份+连续的归档日志文件来完成我们的数据库恢复工作。另注, 可以直接通过命令"recover database" 来完成整个恢复过程,不过这样感觉缺乏成就感.除非对备份或是自己的水平很有信心,否则不建议使用。以上测试通过。

(T115)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· Oracle中RMAN和EXP/IMP转移数据实测 (12-12) · Oracle数据完整性嵌套事务调用的研究 (12-12)
· Oracle 9i新特性之细粒度访问原则 (12-12) · Linux中使用LiveCD恢复受危害的系统 (12-11)
· 用智能优化限制提高Oracle数据库性能 (12-11) · Oracle体系框架及SQL语句性能探讨 (12-11)
· 用脚本和查询主动监视Oracle 9i性能 (12-11) · Oracle10g用RMAN恢复临时表空间增强 (12-11)
· Oracle新的Linux应用环境测试标准 (12-08) · 优化数据库大幅度提高Oracle的性能 (12-07)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管