`

用Oracle归档日志进行数据库恢复的方法

 
阅读更多

Oracle数据库备份的方法很多,下面就为您介绍用Oracle归档日志进行数据库恢复的方法,希望对您学习Oracle归档日志和数据库备份能有所帮助。

  联机重演日志没有丢失应使用完成恢复,如联机重演日志损坏,而又没有备份,就只能进行不完全恢复。

  一、完全恢复:

  1.使用命令“svrmgrl”调用行方式服务器管理;

  2.输入命令“connect internal”,然后输入命令“startup mount’;

  3.输入命令“recover database;”

  4.按下ENTER,接受默认值。

  5.然后输入命令“alter database open;”完成数据库恢复。

  二、不完全恢复

  警告:

  应用不完成恢复前,必须将数据库做一次完全冷备份,因为应用不完全恢复后,联机重演日志将重置,以前的所有日志不可用。

  如果恢复不成功,数据库就不能使用了。再次强调,做完全冷备份后再应用不完全恢复。

  1)基于变化的恢复(change-based recovery)

  要执行基于变化的恢复,需要知道丢失日志之前的系统写入归档重演日志的最大的变化号(SCN),然后可以启动恢复语句恢复数据库直到改变 scn_number,其中比scn_number是写到已归档重演日志文件顺序号386的SCN(即,小于丢失日志顺序号387的SCN)。可以从 V$log_history视图中得到SCN信息。

  select first_change# from v$log_history where sequence#=387;

  其中387为最后一个有效的日志文件号加1,该例是查找386.

  知道了SCN后,使用下述步骤完成恢复

  1.使用命令“svrmgrl”调用行方式服务器管理;

  2.输入命令“connect internal”,然后输入命令“startup mount’;

  3.输入命令“recover database until change 9999;”

  4.在回答Oracle第一个归档重演日志建议信息时,输入“auto”,Oracle在找到第387号重演日志之前停止恢复。

  5.用命令“alter database open resetlogs;”打开数据库。(应用该命令前请确认数据库已备份,如打开失败,日志将不可用)

  2).基于停止恢复(cancel-based recovery)

  1.使用命令“svrmgrl”调用行方式服务器管理;

  2.输入命令“connect internal”,然后输入命令“startup mount’;

  3.输入命令“recover database until cancel;”,Oracle提示需要的第一个归档重演日志文件名.按下ENTER键接受缺省文件名,并且—路ENTER直到询问顺序号387的日志。输入“cancel”,停止恢复操作。

 

4.用命令“alter database open resetlogs;”打开数据库。(应用该命令前请确认数据库已备份,如打开失败,日志将不可用)

  3).基于时间的恢复(time-based recovery)

  为使用基于时间的恢复,必须知道记录在V$log_history归档重演日志序号387(丢失重演日志)的时间,通过执行查询语句 “select time from v$log_history where sequence#=387;”得到。本例得到的时间是:2002-06-23 14:42:04

  现在开始实施恢复。

  1.使用命令“svrmgrl”调用行方式服务器管理;

  2.输入命令“connect internal”,然后输入命令“startup mount’;

  3.输入命令“recover database until time '2002/06/23 14:42:04';”,Oracle提示需要的第一个归档重演日志文件名,输入“auto”,Oracle恢复归档重演日志直到序号为387的日志,停止恢复操作。

  4.用命令“alter database open resetlogs;”打开数据库。(应用该命令前请确认已数据库已备份,如打开失败,日志将不可用)

  提示: 使用基于时间的恢复,时间的格式是YYYY/MM/DD HH24:MI:SS,并且用单引号括起。

  附:如何启用Oracle的归档方式

  1.参照以下内容编辑init.ora文件:

  log_archive_start = true

  log_archive_dest_1 = " LOCATION=D:\Oracle\oradata\ORCL\archive "

  og_archive_format = %%ORACLE_SID%%T%TS%S.ARC

  2.关闭数据库

  svrmgrl> connect internal

  svrmgrl> shutdown normal

  3.然后启动实例并安装该数据库,但不打开数据库。

  svrmgrl> startup mount

  4.接着,发布下列更改数据库的命令。

  Svrmgrl> alter database archivelog;

  5.现在,数据库已经更改为归档方式,您可以打开数据库。

  svrmgrl> alter database open;

  提示:也可以使用DBA studio工具启用数据库的归档方式,操作很简单

分享到:
评论

相关推荐

    ORACLE归档日志设置

    ORACLE归档日志设置 ORACLE数据库的归档日志设置是一种...ORACLE归档日志设置是一种重要的机制,旨在保障数据库的安全性和灾难恢复能力。通过设置数据库的日志模式和自动归档模式,可以确保数据库的可靠性和可恢复性。

    如何正确删除Oracle归档日志

    正确地删除Oracle归档日志不仅能够有效释放磁盘空间,还能保证数据库的稳定运行。通过上述介绍的步骤和注意事项,DBA们可以更加高效且安全地管理归档日志,从而提升整个数据库系统的性能和可靠性。

    Oracle清除归档日志

    #### 一、Oracle归档日志简介 Oracle数据库中的归档日志包含了所有事务处理的更改记录,用于数据库恢复操作。归档日志是在数据库处于归档模式下,当重做日志文件填满并进行切换时生成的。归档日志存储在指定的位置...

    oracle归档日志挖掘详细步骤.docx

    Oracle数据库归档日志挖掘是数据库管理中一项重要的任务,特别是在数据恢复、审计或问题排查时。本操作手册提供了一套详细的步骤,适用于对Oracle不太熟悉的用户,旨在帮助他们理解和执行归档日志的分析。 首先,...

    ORACLE数据库调整归档日志空间大小[收集].pdf

    ORACLE数据库的归档日志是一种重要的灾难恢复机制,它可以帮助数据库管理员在发生灾难时恢复数据库。然而,如果不正确地配置和维护归档日志,可能会导致数据库无法启动或连接。本文将介绍如何调整ORACLE数据库的归档...

    Oracle-归档日志详解(运行模式、分类)

    Oracle 归档日志是 Oracle 数据库中的一种日志机制,用于记录数据库的所有变化,以便在出现问题时进行恢复。归档日志可分为在线重做日志和归档重做日志两大类。 在线重做日志(Online Redo Log) 在线重做日志是 ...

    oracle归档日志的开启及删除.docx

    Oracle归档日志的开启、关闭和删除 Oracle数据库中的归档日志(Archive Log)是一种重要的日志机制,用于记录数据库中的所有操作,以便在数据库崩溃或系统故障时能够快速恢复数据。然而,打开归档日志模式后,会...

    oracle通过日志查看数据库变更情况.txt

    下面将详细介绍如何利用Oracle的重做日志(Redo Log)和归档日志(Archived Logs)来分析数据库的变更记录。 ### Oracle日志系统概览 Oracle数据库的日志系统主要包括重做日志(Redo Log)和归档日志(Archived ...

    oracle 如何把数据库变为非归档日志模式

    ### Oracle 数据库转换至非归档日志模式详解 #### 一、背景介绍 在Oracle数据库管理中,根据业务需求的不同,可能需要将数据库的工作模式从归档模式切换至非归档模式。归档模式虽然提供了强大的数据恢复能力,但...

    Oracle数据库非归档模式重做日志恢复方法.pdf

    【Oracle数据库非归档模式重做日志恢复方法】 在Oracle数据库系统中,重做日志文件(Redo Log File)扮演着至关重要的角色。它们记录了所有对数据库的事务性更改,确保在系统崩溃或异常关闭后能够进行实例恢复,以...

    Oracle归档日志空间不足引发的问题及归档日志的检测与删除

    综上所述,了解和管理Oracle归档日志对于确保数据库的稳定运行至关重要。通过对归档日志的监控、适时的删除策略和合理的空间规划,可以有效避免因归档日志空间不足引发的问题,保障数据库的高效运行。

    Centos7.6下Oracle开启归档日志和Rman恢复.docx

    本文主要讨论如何在Oracle数据库中开启归档日志模式以及如何使用RMAN(恢复管理器)进行数据恢复。 首先,归档日志模式对于数据库的完整性和可恢复性至关重要。在Oracle数据库中,归档日志模式记录了所有事务的更改...

    Oracle归档日志删除

    Oracle归档日志是数据库运行过程中产生的事务日志的备份,用于在发生故障时进行数据恢复。当数据库在归档模式下运行时,每次检查点都会生成新的归档日志,以便在系统崩溃或介质故障后能够恢复到一致的状态。然而,...

    oracle RAC集群开启归档日志.docx

    Oracle RAC 集群开启归档日志是指在 Oracle RAC 集群环境中启用归档日志功能,以便提高数据库的可靠性和可维护性。为了实现这一功能,需要修改集群参数文件,重启数据库。 在开启归档日志之前,需要查看当前的归档...

    oracle归档日志删除

    在 Oracle 中,归档日志的删除是非常重要的,因为归档日志满可能会导致数据库启动不起来或数据库不能正常使用。以下是关于 Oracle 归档日志删除的知识点: 查看 Oracle 归档日志大小 查看 Oracle 归档日志大小可以...

    Oracle 删除归档日志实例

    归档日志是Oracle数据库为了支持数据恢复而创建的一种特殊类型的日志文件。它们包含了所有事务处理的更改信息,可以在数据库崩溃或者需要恢复时用来恢复数据。在归档模式下,每当一个重做日志文件组被填满并且提交时...

    删除ORACLE归档日志

    本文将详细解释如何在Windows和Linux系统上使用脚本删除Oracle归档日志,并讨论相关知识点。 首先,删除Oracle归档日志前,我们需要理解以下几个关键概念: 1. **归档模式**:当Oracle数据库运行在归档模式下,...

    Oracle归档日志管理

    Oracle归档日志非常重要,对归档日志的管理更加重要,本文主要讲解Oracle归档日志方面的各种管理,值得收藏。

Global site tag (gtag.js) - Google Analytics