【恢复,1】 redo 日志恢复的各种情况

Recovering After the Loss of Online Redo Log Files

If a media failure has affected the online redo logs of a database, then the appropriate
recovery procedure depends on the following considerations:

  • The configuration of the online redo log: mirrored or non-mirrored
  • The type of media failure: temporary or permanent
  • The types of online redo log files affected by the media failure: current, active, unarchived, or inactive

Table 30-3 displays V$LOG status information that can be crucial
in a recovery situation involving online redo logs.

Table 30-3 STATUS Column of V$LOG

Status Description

UNUSED


The online redo log has never been written to.


CURRENT


The online redo log is active, that is, needed for instance recovery, and it is the log to which the database is currently writing. The redo log can be open or closed.


ACTIVE


The online redo log is active, that is, needed for instance recovery, but is not the log to which the database is currently writing. It may be in use for block recovery, and may or may not be archived.


CLEARING


The log is being re-created as an empty log after an ALTER DATABASE CLEAR LOGFILE statement. After the log is cleared, then the status changes to UNUSED.


CLEARING_CURRENT


The current log is being cleared of a closed thread. The log can stay in this status if there is some failure in the switch such as an I/O error writing the new log header.


INACTIVE


The log is no longer needed for instance recovery. It may be in use for media recovery, and may or may not be archived.

Recovering After Losing a Member of a Multiplexed Online Redo Log Group

You can recover after losing a member of a multiplexed online redo log group. The database continues to function as usual during the following conditions:

If the online redo log of a database is multiplexed, and if at least one member of each online redo log group is not affected by the media failure, then the database continues functioning as usual, but error messages are written to
the log writer trace file and the alert_SID.log of the database.

You can resolve the problem of a missing member of a multiplexed online redo log group by taking one of the following actions:

  • If the hardware problem is temporary, then correct it. The log writer process accesses the previously unavailable online redo log files as if the problem never existed.
  • If the hardware problem is permanent, then drop the damaged member and add a new member by using the following procedure.

    Note:

    The newly added member provides no redundancy until the log group is reused.

  1. Locate the file name of the damaged member in V$LOGFILE. The status is INVALID if the file is inaccessible:

    SELECT GROUP#, STATUS, MEMBER
    FROM V$LOGFILE
    WHERE STATUS=‘INVALID‘;
    
    GROUP#    STATUS       MEMBER
    -------   -----------  ---------------------
    0002      INVALID      /disk1/oradata/trgt/redo02.log
    
  2. Drop the damaged member. For example, to drop member redo02.log from group 2, issue the following statement:
    ALTER DATABASE DROP LOGFILE MEMBER ‘/disk1/oradata/trgt/redo02.log‘;
    
  3. Add a new member to the group. For example, to add redo02.log to group 2, issue the following statement:
    ALTER DATABASE ADD LOGFILE MEMBER ‘/disk1/oradata/trgt/redo02b.log‘
      TO GROUP 2;
    

    If the file that you want to add exists, then it must be the same size as the other group members, and you must specify the REUSE option. For example:

    ALTER DATABASE ADD LOGFILE MEMBER ‘/disk1/oradata/trgt/redo02b.log‘
      REUSE TO GROUP 2;

Recovering After Losing All Members of an Online Redo Log Group

丢失online redo 日志组所有成员后恢复

If a media failure damages all
members of an online redo log group, then different scenarios can occur depending on the type of online redo log group affected by the failure and the archiving mode of the database.

如果介质故障损坏所有的日志组的成员,不同场景下发生的失败影响依赖于日志组类型和数据库的归档模式。

If the damaged online redo log group is current and active, then it is needed for crash recovery; otherwise, it is not. Table
30-4
 outlines the various recovery scenarios.

如果损坏的当前日志组时current和active,那么需要做故障恢复。

Table 30-4 Recovering After the Loss of an Online Redo Log Group

If the Group Is... Then... And You Should...

Inactive


It is not needed for crash recovery


Clear the archived or unarchived group.


Active


It is needed for crash recovery


Attempt to issue a checkpoint and clear the log; if impossible, then you must either use Flashback Database or restore a backup and perform incomplete recovery up to the most recent available redo
log.

试着执行checkpoint和clear日志,如果不能,那么你必须要么使用闪回数据库要么使用转储备份 执行不完全恢复到最近可用的redo log。


Current


It is the redo log that the database is currently writing to


Attempt to clear the log; if impossible, then you must either use Flashback Database or restore a backup and perform incomplete recovery up to the most recent available redo log.

To determine whether the damaged group is active or inactive.

确定损坏的组是否是acitve 或inactive

  1. Locate the file name of the lost redo log in V$LOGFILE and then look for the group number corresponding to it. For
    example, enter:

    SELECT GROUP#, STATUS, MEMBER FROM V$LOGFILE;
    
    GROUP#    STATUS       MEMBER
    -------   -----------  ---------------------
    0001                    /oracle/dbs/log1a.f
    0001                    /oracle/dbs/log1b.f
    0002      INVALID       /oracle/dbs/log2a.f
    0002      INVALID       /oracle/dbs/log2b.f
    0003                    /oracle/dbs/log3a.f
    0003                    /oracle/dbs/log3b.f
    
  2. Determine which groups are active.

    For example, execute the following SQL query (sample output included):

    SELECT GROUP#, MEMBERS, STATUS, ARCHIVED
    FROM V$LOG;
    
    GROUP#  MEMBERS           STATUS     ARCHIVED
    ------  -------           ---------  -----------
     0001   2                 INACTIVE   YES
     0002   2                 ACTIVE     NO
     0003   2                 CURRENT    NO
    
  3. Perform one of the following actions:

Losing an Inactive Online Redo Log Group

丢失inactive 日志组

If all members of an online
redo log group with INACTIVE status are damaged, then the procedure depends on whether you can fix the media problem that damaged the inactive redo log group. If the failure is temporary, then fix the problem. The log writer
can reuse the redo log group when required. If the failure is permanent, then the damaged inactive online redo log group eventually halts normal database operation. Reinitialize the damaged group manually by issuing the ALTER DATABASE
CLEAR LOGFILE
 statement as described in this section.

inactive状态的日志组所有成员损坏。那么程序依赖于你能否定位inactive日志组的介质问题(日志文件是否损坏),如果介质故障是临时的,log writer 能重新使用 日志组。如果介质故障是永久的,那么损坏的inactive日志组最终会停止正常的数据库操作。通过执行alter database CLEAR LOGFILE语句手动的重新初始化损坏的日志组。

Clearing Inactive, Archived Redo

清除inactive 已归档的日志

You can clear an inactive redo log group when the database is open or closed. The procedure depends on whether the damaged group has been archived.

数据库开启或关闭都能 clear inactive 日志组。依赖于损坏的日志组是否归档。

To clear an inactive, online redo log group that has been archived:

  1. If the database is shut down, then start a new instance and mount the database:

    STARTUP MOUNT
    
  2. Reinitialize the damaged log group. For example, to clear redo log group 2, issue the following statement:
    ALTER DATABASE CLEAR LOGFILE GROUP 2;
    
Clearing Inactive, Unarchived Redo

清除 inactive 未归档的日志

Clearing a not-yet-archived redo log allows it to be reused without archiving it. This action makes backups unusable if they were started before the last change in the log, unless the file was taken offline before the first change
in the log. Hence, if you need the cleared log file for recovery of a backup, then you cannot recover that backup. Clearing a not-yet-archived-redo-log, prevents complete recovery from backups due to the missing log.

清除的没有归档的日志允许被被重用。如果日志的最后一次改变之前开始, 这个操作会导致备份不可用,除非日志文件在第一次改变之前被置为offline。此后,如果你需要被清除的日志去做备份恢复,是不能备份恢复的。

To clear an inactive, online redo log group that has not been archived:

清除一个inactive ,日志没有归档:

  1. If the database is shut down, then start a new instance and mount the database:

    SQL> STARTUP MOUNT
    
  2. Clear the log using the UNARCHIVED keyword.

    For example, to clear log group 2, issue the following SQL statement:

    SQL> ALTER DATABASE CLEAR UNARCHIVED LOGFILE GROUP 2;
    

    If there is an offline data file that requires the cleared log to bring it online, then the keywords UNRECOVERABLE DATAFILE are required. The data file must be
    dropped because the redo logs necessary to bring the data file online are being cleared, and there is no copy of it. For example, enter:

    如果有一个数据文件offline, 需要清除日志后使数据文件上线,那么此时需要使用关键字UNRECOVERABLE DATAFILE.数据文件必须被删除因为

    SQL> ALTER DATABASE CLEAR UNARCHIVED LOGFILE GROUP 2 UNRECOVERABLE DATAFILE;
    
  3. Immediately back up all data files in the database with an operating system utility, so that you have a backup you can use for complete recovery without relying on the cleared log group. For example, enter:

    立即备份所有的数据文件使用操作系统工具,以至于你有一个不用依赖被清除的日志组就能做完全恢复的备份,

    % cp /disk1/oracle/dbs/*.dbf /disk2/backup
    
  4. Back up the database‘s control file with the ALTER DATABASE statement. For example, enter:
    SQL> ALTER DATABASE BACKUP CONTROLFILE TO ‘/oracle/dbs/cf_backup.f‘;
    
Failure of CLEAR LOGFILE Operation

失败的清除日志文件操作

The ALTER DATABASE CLEAR LOGFILE statement
can fail with an I/O error due to media failure when it is not possible to:

alter database clear logfile 语句如果不能做下面的操作 会失败由于介质故障导致的io错误,

  • Relocate the redo log file onto alternative media by re-creating it under the currently configured redo log file name

    通过当前配置的日志文件的名称重新创建日志文件 迁移日志日志到另外的介质上

  • Reuse the currently configured log file name to re-create the redo log file because the name itself is invalid or unusable (for example, due to media failure)

    重新使用当前的配置日志文件的名称去重新创建日志文件因为他自己的名字是无效的或者不可用。

In these cases, the ALTER DATABASE CLEAR LOGFILE statement
(before receiving the I/O error) would have successfully informed the control file that the log was being cleared and did not require archiving. The I/O error occurred at the step in which the CLEAR LOGFILE statement
attempted to create the new redo log file and write zeros to it. This fact is reflected in V$LOG.CLEARING_CURRENT.

在这些情况下,alter database clear logfile 语句

Losing an Active Online Redo Log Group

If the database is still running and the lost active redo log is not the current log, then issue the ALTER SYSTEM CHECKPOINT statement.
If the operation is successful, then the active redo log becomes inactive, and you can follow the procedure in "Losing
an Inactive Online Redo Log Group"
. If the operation is unsuccessful, or if your database has halted, then perform one of procedures in this section, depending on the archiving mode.

The current log is the one LGWR is currently writing to. If a LGWR I/O operation fails, then LGWR terminates and the instance fails. In this case, you must restore
a backup, perform incomplete recovery, and open the database with the RESETLOGS option.

Recovering from the Loss of Active Logs in NOARCHIVELOG Mode

In this scenario, the database archiving mode is NOARCHIVELOG.

To recover from the loss of an active online log group in NOARCHIVELOG mode:

  1. If the media failure is temporary, then correct the problem so that the database can reuse the group when required.
  2. Restore the database from a consistent, whole database backup (data files and control files). For example, enter:
    % cp /disk2/backup/*.dbf $ORACLE_HOME/oradata/trgt/
    
  3. Mount the database:
    STARTUP MOUNT
    
  4. Because online redo logs are not backed up, you cannot restore them with the data files and control files. To allow the database to reset the online redo logs, you must first mimic incomplete recovery:
    RECOVER DATABASE UNTIL CANCEL
    CANCEL
    
  5. Open the database using the RESETLOGS option:
    ALTER DATABASE OPEN RESETLOGS;
    
  6. Shut down the database consistently. For example, enter:
    SHUTDOWN IMMEDIATE
    
  7. Make a whole database backup.

If the media failure is temporary, then correct the problem so that the database can reuse the group when required. If
the media failure is not temporary, then use the following procedure.

Recovering from Loss of Active Logs in ARCHIVELOG Mode

In this scenario, the database archiving mode is ARCHIVELOG.

To recover from loss of an active online redo log group in ARCHIVELOG mode:

  1. Begin incomplete media recovery, recovering up through the log before the damaged log.
  2. Ensure that the current name of the lost redo log can be used for a newly created file. If not, then rename the members of the damaged online redo log group to a new location. For example, enter:
    ALTER DATABASE RENAME FILE "/disk1/oradata/trgt/redo01.log" TO "/tmp/redo01.log";
    ALTER DATABASE RENAME FILE "/disk1/oradata/trgt/redo02.log" TO "/tmp/redo02.log";
    
  3. Open the database using the RESETLOGS option:
    ALTER DATABASE OPEN RESETLOGS;
    

    Note:

    All updates executed from the end point of the incomplete recovery to the present must be re-executed.

Loss of Multiple Redo Log Groups

If you have lost multiple groups of the online redo log, then use the recovery method for the most difficult log to recover. The order of difficulty, from most difficult to least
difficult, is as follows:

  1. The current online redo log
  2. An active online redo log
  3. An unarchived online redo log
  4. An inactive online redo log

    来源: <http://docs.oracle.com/cd/E11882_01/backup.112/e10642/osadvsce.htm#BRADV99985>

时间: 2024-08-06 17:30:29

【恢复,1】 redo 日志恢复的各种情况的相关文章

【恢复】Redo日志文件丢失的恢复

第一章 Redo文件丢失的恢复 1.1  online redolog file 丢失 联机Redo日志是Oracle数据库中比较核心的文件,当Redo日志文件异常之后,数据库就无法正常启动,而且有丢失据的风险,强烈建议在条件允许的情况下,对Redo日志进行多路镜像.需要注意的是,RMAN不能备份联机Redo日志文件.所以,联机Redo日志一旦出现故障,则只能进行清除日志了.清除日志文件即表明可以重用该文件. 1.1.1  数据库归档/非归档模式下inactive redo异常ORA-00316

【Oracle】数据库运行状态下物理删除所有redo日志恢复方法

实验环境: OEL5.6  Oracle11.2.0.1 实验开始: 数据库运行状态,删除所有日志: [[email protected] TEST]$ ls control01.ctl  redo01.log  sysaux01.dbf  undotbs01.dbf data_ol01.dbf  redo02.log  system01.dbf  users01.dbf example01.dbf  redo03.log  temp01.dbf [[email protected] TEST]

Redo日志

当向存储系统写一个数据元素时,通常是先写入主存或者缓冲,然后再写入磁盘,如果系统在写入磁盘的时候,系统发生故障,当系统恢复后,需要再次从磁盘中读取此数据元素的时候,并不知道此时磁盘上所保存的数据元素是正确的还是错误的,Redo日志是一种应对此种故障的比较常用的故障恢复策略.为了确保一个数据元素的完整性,还需要借助事务这一概念,对于更新数据一个元素的redo日志,我们将其描述为"在一个事物T中写入数据元素A的新值x",使用元组<T, A, x>表示. 一个事务的数据元素的更新

Oracle非关键文件恢复,redo、临时文件、索引文件、密码文件

增量备份的应用在recovery阶段,不再restore阶段 了解数据库设置表: SQL>desc database_properties Name                                      Null?    Type ----------------------------------------- -------- ---------------------------- PROPERTY_NAME                             NO

浅谈SQL Server中的事务日志(四)----在完整恢复模式下日志的角色

浅谈SQL Server中的事务日志(四)----在完整恢复模式下日志的角色 本篇文章是系列文章中的第四篇,也是最后一篇,本篇文章需要前三篇的文章知识作为基础,前三篇的文章地址如下: 浅谈SQL Server中的事务日志(一)----事务日志的物理和逻辑构架 浅谈SQL Server中的事务日志(二)----事务日志在修改数据时的角色 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色 简介 生产环境下的数据是如果可以写在资产负债表上的话,我想这个资产所占的数额一定不会

mysqldump备份结合binlog日志恢复

http://hongge.blog.51cto.com/ MySQL备份一般采取全库备份加日志备份的方式,例如每天执行一次全备份,每小时执行一次二进制日志备份.这样在MySQL故障后可以使用全备份和日志备份将数据恢复到最后一个二进制日志备份前的任意位置或时间. 1.binlog介绍 mysql的二进制日志记录着该数据库的所有增删改的操作日志(前提是要在自己的服务器上开启binlog),还包括了这些操作的执行时间.为了显示这些二进制内容,我们可以使用mysqlbinlog命令来查看. Binlo

mysql-binlog日志恢复数据库

binlog日志用于记录所有更新了数据或者已经潜在更新了数据的所有语句.语句以“事件”的形式保存,它描述数据更改.当我们因为某种原因导致数据库出现故障时,就可以利用binlog日志来挽回(前提是已经配置好了binlog),接下来我们来配置 一.开启mysql-binlog日志 在mysql配置文件my.cnf加上如下配置 [mysqld] log-bin=mysql-bin 重启mysql service mysqld restart 二.备份数据库 1)先查看一下当前数据库情况 mysql>

通过sqlserver日志恢复误删除的数据

原文:通过sqlserver日志恢复误删除的数据 如果你已经急的焦头烂额,看到这篇文章的时候,请你换个坐姿,深呼吸几次,静下心来将这篇文章读完,也许你的问题迎刃而解. 我遇到的情况是这样的,网站被植入木马,盗取了我的web.config文件,web.config文件里面的数据库连接字符串没有加密,而我的数据库远程连接又没有做IP限制,黑客通过数据库客户端连上我的数据库后,将所有的表都Delete掉了,所以大家一定要有一个好习惯将数据库连接字符串加密或者对远程访问数据库的IP作限制. 因被黑客De

MySQL系列:innodb源码分析之redo log恢复

在上一篇<innodb源码分析之重做日志结构>中我们知道redo log的基本结构和日志写入步骤,那么redo log是怎么进行数据恢复的呢?在什么时候进行redo log的日志推演呢?redo log的推演只有在数据库异常或者关闭后,数据库重新启动时会进行日志推演,将数据库状态恢复到关闭前的状态.那么这个过程是怎么进行的呢?以下我们逐步来解析. 1.recv_sys_t结构 innodb在MySQL启动的时候,会对重做日志文件进行日志重做,重做日志是通过一个recv_sys_t的结构来进行数