`

ORACLE_RESETLOGS浅析

 
阅读更多

alter database open resetlogs 这个命令我想大家都很熟悉了,那有没有想过这个resetlogs选项为什么要用?什么时候用?
它的原理机制是什么?他都起哪些作用?

我们都知道数据在启动时候是要做一致性检查的,oracle在open阶段要做两次检查

1. 检查数据文件头的检查点计数(checkpoint cnt)是否和控制文件的检查点计数(checkpoint cnt)一致。目的是确认数据文件是否来自同一版本,而不是从备份中恢复的。如果这一步检查通过,就进行第二步检查  

SELECT CHECKPOINT_CHANGE# FROM V$DATAFILE_HEADER;
SELECT CHECKPOINT_CHANGE# FROM V$DATAFILE;

 

2. 检查数据文件头的开始scn和控制文件中记录该文件的结束scn是否一致。如果数据文件头的开始scn和控制文件中该文件的结束 scn 相等,那说明这个数据文件就不需要恢复,否则就要恢复文件

SELECT CHECKPOINT_CHANGE# FROM V$DATAFILE_HEADER;  
SELECT LAST_CHANGE# FROM V$DATAFILE;

 
如果以上两步检查都通过,那就可以正常打开数据库,锁定数据文件,同时将控制文件中每个数据文件的结束scn设置无穷大。
我们在某些条件下打开数据,会提示让用resetlogs选项open数据库,为什么要用resetlogs呢?它是干嘛用的呢?问号一大堆了吧,
下面来具体分析下。

resetlogs的作用

防止陈旧的数据进入数据库(保证数据库的一致性),这也就是为什么在用resetlogs打开数据库,一定要立即对数据库做个全备。
在控制文件,data file header,redo log header里存储”resetlogs data“,当open resetlogs被执行时,可以通过这些内容检查一致性。

什么时候用resetlogs

1. 不完全恢复
2. 用备份的控制文件恢复
3. 新创建的控制文件来恢复

resetlogs的原理机制

resetlogs是如何来保证打开数据库是一致的呢?

1)在open resetlogs时,oracle要对比检查控制文件和数据字典file$,如果一个数据文件在file$中存在,但在控制文件中不存在,
   那在控制文件中将创建一个这个文件条目(MISSINGnnn ‘nnn’是十进制的file_id),同时这个文件被标记为离线并需要恢复。如果
   实际中这个文件存在的话,可以通过如下sql更改到正确的文件名。

   sql> alter database rename file 'MISSINGnnn' to '<filename>';

   然后数据文件被恢复,online。

2)如果一个数据文件存在控制文件中,而不在数据字典file$中,那么直接把控制文件中这个文件的记录条目删除(oracle认为file$文
   件是正确的,要以它为准)

3)当用旧的备份控制文件恢复的时候,如果有数据文件不在控制文件中注册(会提示控制文件比较旧的错误),那就不得不重建数据文件
   ,以使数据文件注册到控制文件中,然后系统会自动利用redo/archivelog恢复这个数据文件。

在保证控制文件和file$文件内容一致之后,oracle还有做如下检查才能open resetlogs

4)数据文件的版本要小于当前数据库的版本(counter)

5)offline的数据文件必须被online或者直接drop

6)所有的数据文件不能设置fuzzy bit,所有的数据文件要有相同的检查点(checkpoint SCN)

到目前为止,open resetlogs的前提条件都已经满足,resetlogs究竟做了哪些工作呢?(重新使用redo log)

1)所有的online logfile 的信息重新被放置在控制文件中。并且还要为有效的thread挑选一个logfile文件作为current logfile

2)log header被更新为log seq#

3)所有的online的数据文件头被新的checkpoint和新的‘resetlogs data’更新,offline的数据文件被标记为需要媒体恢复。

resetlogs data:当前的scn和counter被称作”resetlogs data“


如果oracle数据库一致性检查失败的,那数据库是不允许被open的,即 open resetlogs不成功。但也不是绝对不能open,可以通过隐含参数“_allow_resetlogs_curruption”,绕过oracle 的一致性检查,但这样会引起数据库的不一致(文件可能有不同的scn或有fuzzy bit设置),如果open后,数据库一定要rebuild (建议ANALYZE TABLE ...VALIDATE  STRUCTURE  CASCADE;或者imp/exp )

分享到:
评论

相关推荐

    Open resetlogs操作对Oracle数据库恢复的影响.pdf

    3. Oracle数据库的版本特性:Oracle9i与Oracle10g及以上版本在数据库恢复操作中的差异,特别是对于resetlogs操作和归档日志新格式的应用。 4. 数据库备份的策略和技巧:掌握如何在不同的应用场景下,制定合理的...

    ORACLE_数据库备份和恢复

    在某些情况下,可能还需要使用`ALTER DATABASE OPEN RESETLOGS`命令来清理并重新初始化重做日志,以避免日志文件的混淆。 总的来说,Oracle数据库的备份和恢复是一个复杂而重要的过程,需要深入了解数据库的内部...

    ORACLE_OCP10g学习笔记.pdf

    - **RESETLOGS相关概念**:RESETLOGS选项在恢复过程中的作用。 - **SCN概念**:System Change Number,用于跟踪数据库中的更改。 #### 十四、Oracle全球化特性 - **字符集**:数据库支持的不同字符集。 - **语言...

    三思Oracle_RMAN数据备份恢复

    RMAN&gt; ALTER DATABASE OPEN RESETLOGS; ``` 四、RMAN的高级特性 1. 块级增量备份:RMAN支持块级增量备份,只备份自上次备份以来改变的数据块,显著减少备份时间。 2. 备份验证:RMAN提供验证功能,可检查备份的...

    Oracle_RMAN(备份与恢复管理器)

    - **Incarnation (对应物)**:在不完全恢复后重新打开数据库时通常需要使用`RESETLOGS`选项。这标志着一个数据库逻辑生存周期的结束和下一个逻辑生存周期的开始,这种逻辑生存周期被称为“对应物”。 #### 三、RMAN...

    oracle非归档模式丢失全部联机日志后的处理方法

    * 在使用隐含参数进行处理时,需要添加 _allow_resetlogs_corruption=TRUE 参数。 * 在打开数据库时,可能出现 ORA-00603 错误,可以通过多次重起数据库解决。 * 在处理过程中,需要多次重起数据库以解决错误。 ...

    巧妙设置Oracle9i自动逻辑备份.pdf

    SEND 'NB_ORACLE_CLIENT=CallCenter.NB_ORACLE_POLICY=dbcenter_oracle_full,NB_ORACLE_SERV=BakSentr'; RESTORE DATABASE; RECOVER DATABASE UNTIL LOG SEQUENCE 1103 THREAD 1; ALTER DATABASE OPEN RESETLOGS...

    oracle备份恢复五个案例

    Oracle提供了一个隐含参数`_allow_resetlogs_corruption`,在启用后,允许在重置日志时忽略潜在的数据损坏。然而,这应作为最后手段,因为可能会永久丢失数据。在使用此参数前,应先尝试其他恢复策略,并充分理解其...

    PS_ResetLogs:在重新生成日志文件之前,重置日志文件(可选),并通过电子邮件发送(可选)

    重置日志 什么是重置日志 Reset-Logs是一个小的实用程序,它接收一个日志文件(不能锁定),并且 [可选]以其他名称将其移至已存档状态 [可选]通过电子邮件将其发送到特定地址 使用[Optional]标头重新创建 ...

    用NetBackup恢复Oracle数据库到异机

    - 使用`ALTER DATABASE OPEN RESETLOGS`命令前,检查数据文件的状态,如有未恢复的数据文件,需要先进行恢复操作。 总的来说,使用NetBackup恢复Oracle数据库到异机是一个涉及多个步骤的过程,需要细心操作并密切...

    oracle 11g rman 全备份脚本

    6. **`alter database open resetlogs;`**: 打开数据库,并重置日志序列号。 以上步骤实现了从备份文件恢复整个数据库的过程。 #### 四、其他操作 此外,脚本还包括了恢复服务器参数文件(SPFILE)的操作: 1. *...

    解决ORACLE联机日志文件无故全部消失问题

    因此,我们需要设置隐含参数 `_allow_resetlogs_corruption=TRUE` 来恢复当前联机日志: ``` SQL&gt; alter system set "_allow_resetlogs_corruption"=TRUE; ``` 然后,我们可以执行以下 SQL 命令来恢复当前联机日志...

    oracle_rman

    5. **打开数据库**:最后,使用`alter database open resetlogs`命令打开数据库,此时数据库状态为新数据库,但数据和事务一致性与源环境相同。 需要注意的是,异机恢复可能涉及额外的权限和网络设置,确保源和目标...

    Oracle9个_name介绍

    - 重建控制文件并以`resetlogs`方式打开数据库。 - 使用`nid`工具进行更改。 - **限制**:在创建数据库时,`db_name`的长度被限制为最多8个字符,尽管在Oracle 10g中创建时不会出现错误提示,但实际存储的字符长度...

    ORA-00600【4194】.pdf

    在本文中,我们使用了两个隐含参数:*_allow_resetlogs_corruption=TRUE 和 *.undo_management='manual'。第一个参数允许数据库在启库时恢复日志文件,第二个参数设置Undo 表空间的管理方式为手动。 知识点2: Undo...

    REDO文件block损坏的解决方法

    首先,需在Oracle参数文件中设置`_allow_resetlogs_corruption=true`,这一设置允许数据库在redo日志块损坏的情况下进行resetlogs操作。注意,此参数仅在特殊情况下使用,应谨慎操作。 #### 步骤2:数据库实例重启 ...

    Oracle11g 崩溃后-dbf数据库文件恢复

    6. **打开数据库**:最后,使用`ALTER DATABASE OPEN RESETLOGS`命令打开数据库,这将创建新的重做日志组并更新控制文件。 7. **验证数据**:打开数据库后,进行全面的数据验证,确保所有表和索引都处于一致状态。 ...

    Bug 18411339 Low performance or ORA-1220

    and lh.resetlogs_change# = di.resetlogs_change# and di.status = 'CURRENT' and lh.thread# is not null and lh.resetlogs_change# is not null and lh.resetlogs_time is not null group by lh....

    Oracle 11g rman 异机还原再升级到 12c PDB

    - `abc.__oracle_base='/u01/app/oracle'` # ORACLE_BASE set from environment - `abc.__pga_aggregate_target=314572800` - `abc.__sga_target=465567744` - `abc.__shared_io_pool_size=0` - `abc.__shared_...

Global site tag (gtag.js) - Google Analytics