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

2016-02-19 19:48 80 1 收藏

图老师设计创意栏目是一个分享最好最实用的教程的社区,我们拥有最用心的各种教程,今天就给大家分享Oracle的Archive Log模式下的恢复工作的教程,热爱PS的朋友们快点看过来吧!

【 tulaoshi.com - 编程语言 】

学习并测试了一下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" 来完成整个恢复过程,不过这样感觉缺乏成就感.除非对备份或是自己的水平很有信心,否则不建议使用.
  
  以上测试通过.

来源:http://www.tulaoshi.com/n/20160219/1621827.html

延伸阅读
如果您目前拥有一个冷备份,但是缺少了其中的一个数据文件,但你目前存在所有的归档,如果您要恢复数据文件,可以参考以下的示例:   代码如下: [oracle@jumper eygle]$ sqlplus "/ as sysdba"  SQL*Plus: Release 9.2.0.4.0 - Production on Sun Aug 20&...
皮肤发热 如果持续在高温暴晒的情景下,即使涂了防晒霜,也可能难以抵挡住强紫外线的辐射。当你开始感受到皮肤晒到滚烫、发热,此时皮肤已经处于缺水状态了,要及时给皮肤补水降温。 方法:最简单有效的方法就是随身携带一瓶小喷雾,以备能及时在各个发热的部位喷上。 皮肤发痛 皮肤晒至发热,如果没有及时补水或移步至阴凉...
3.1.1 直接管理模式 直接管理模式的原理如图3.1所示,共有3层结构。 1. 管理客户机 在管理客户机上安装,通过调用其他的集成管理工具,利用SQL *NET协议建立与数据库服务器的连接。 2. 连接网络 常用TCP/IP协议构建连接网络。 3. 数据库服务器组 分布式的数据库服务器组,服务器运行SQL *NET协议响应...
游戏是孩子的工作(下) (接上文) 一二岁前幼儿的发展 通常是一个人玩;以自我为中心,有占有欲;会有“连续但漫无目的”的动作,能看、听、感觉;会抓、握东西;能将东西拆开、组合、拿出、放入;能爬行、投掷和跳跃;具有强烈的好奇心。此时期为他准备的玩具可以是:便于投掷、抓握的柔软玩具;不易破损的玩偶、娃娃;铃铛、音光盒;可...
方法1: X:\oracle\ora81\bin\wrap   iname=XXX   oname=XXX    方法2:9i在win2000下使用wrap加密存储过程,10g可以用加密包dbms_ddl.wrap或dbms_ddl.create_wrapped。 11.5.1 在win2000下使用wrap加密存储过程 wrap.bat rem 使用方法:wrap 待加密的文件名 set ...

经验教程

415

收藏

42
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部