iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Redo丢失怎么处理
  • 674
分享到

Redo丢失怎么处理

2024-04-02 19:04:59 674人浏览 薄情痞子
摘要

这篇文章主要介绍Redo丢失怎么处理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一.说明:1.以下所说的当前日志指日志状态为CURRENT,ACTIVE,非当前日志指日志状态为IN

这篇文章主要介绍Redo丢失怎么处理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!



一.
说明:
1.以下所说的当前日志指日志状态为CURRENT,ACTIVE,非当前日志指日志状态为INACTIVE
2.不用考虑归档和非归档模式,2种模式下的Redo丢失情况一样。


二.丢失Redo的4种情况:

第一种情况:非当前日志,正常关闭。
第二种情况:非当前日志,非正常关闭。
第三种情况:当前日志,正常关闭。
第四种情况:当前日志,非正常关闭。


三.处理方法:

第一、二种情况的处理方法一样,直接把日志文件clear即可。
sql> alter database clear logfile group 3;
SQL> alter database clear unarcHived logfile group 3;//如果INACTIVE状态的在线Redo还未归档,增加关键字unarchived完成clear操作。(ACTIVE,INACTIVE都有可能未完成归档,归档是否完成可以查看v$log.archived字段)。

例子:

SQL> startup mount

oracle 例程已经启动。


Total System Global Area  263639040 bytes

Fixed Size                  1384012 bytes

Variable Size             167772596 bytes

Database Buffers           88080384 bytes

Redo Buffers                6402048 bytes

数据库装载完毕。

SQL> select group#,thread#,status,archived from v$log;

    GROUP#    THREAD# STATUS                           ARCHIV

---------- ---------- -------------------------------- ------

         1          1 CURRENT                          NO

         3          1 ACTIVE                           NO

         2          1 INACTIVE                         YES


SQL> alter database clear logfile group 3;

alter database clear logfile group 3

*

第 1 行出现错误:

ORA-01624: 日志 3 是紧急恢复实例 orcl (线程 1) 所必需的

ORA-00312: 联机日志 3 线程 1: 'E:\APP\ORADATA\ORCL\REDO03.LOG'


SQL> alter database clear logfile group 2;


数据库已更改。


第三种情况的处理办法:
SQL>startup mount;
SQL>recover database until cancel;
SQL>alter database open resetlogs;

例子1:

SQL> shutdown immediate

数据库已经关闭。

已经卸载数据库。

ORACLE 例程已经关闭。

SQL> startup mount

ORACLE 例程已经启动。

Total System Global Area  263639040 bytes

Fixed Size                  1384012 bytes

Variable Size             167772596 bytes

Database Buffers           88080384 bytes

Redo Buffers                6402048 bytes

数据库装载完毕。

SQL> alter database open resetlogs;

alter database open resetlogs

*

第 1 行出现错误:

ORA-01139: RESETLOGS 选项仅在不完全数据库恢复后有效

SQL> recover database until cancel;

完成介质恢复。

SQL> alter database open resetlogs;

数据库已更改。

例子2(第三种情况的第二个处理方法):


SQL> shutdown immediate

数据库已经关闭。

已经卸载数据库。

ORACLE 例程已经关闭。

SQL> startup mount

ORACLE 例程已经启动。


Total System Global Area  263639040 bytes

Fixed Size                  1384012 bytes

Variable Size             167772596 bytes

Database Buffers           88080384 bytes

Redo Buffers                6402048 bytes

数据库装载完毕。

SQL> select group#,thread#,status,archived from v$log;


    GROUP#    THREAD# STATUS                           ARCHIV

---------- ---------- -------------------------------- ------

         1          1 CURRENT                          NO

         3          1 INACTIVE                         YES

         2          1 INACTIVE                         YES


SQL> alter database clear logfile group 2;

数据库已更改。

SQL> alter database clear logfile group 3;

数据库已更改。

SQL> alter database clear unarchived logfile group 1;

数据库已更改。

    这里CURRENT的Redo日志文件组能被clear unarchived。


SQL> alter database open;

数据库已更改。

    如果Redo日志文件丢失,clear操作完成之后将在原有位置创建新的Redo日志文件。


第四种情况的处理方法:

1.通过备份来还原、恢复数据。
2.通过修改参数文件中的参数
_allow_resetlogs_corruption=TRUE
来强制启动数据库。<<<<  虽然能够启动数据库到open状态,但是启动后的数据库数据字典、数据有可能导致不一致的情况出现,故需要在open下把整个数据库export,然后删除库,重建,再将export的数据import到新的数据库中。

四.验证数据库是否正常关闭的方法

SQL> select open_mode from v$database;

OPEN_MODE

--------------------

READ WRITE


SQL> select status from v$instance;

STATUS

------------

OPEN


SQL> select file#,checkpoint_change#,fuzzy from v$datafile_header;

     FILE# CHECKPOINT_CHANGE# FUZ

---------- ------------------ ---

         1            1165820 YES

         2            1165820 YES

         3            1165820 YES

         4            1165820 YES

    FUZZY bit in datafile header means that there may have been writes into a datafile after the last checkpoint. E.g. there may be changes written to datafile with higher SCN than checkpoint_change# stored in datafile header (seen from v$datafile_header.checkpoint_change#).
        FUZYY表示模糊性,意思是,该数据文件处于模糊状态,在最近一次CHECKPOINT后,该文件上的数据可能被修改过了,但没来得及更新到该文件上(或者该文件不知道),需要读取日志信息来判断。


SQL> select file#,checkpoint_change#,last_change# from v$datafile;

     FILE# CHECKPOINT_CHANGE# LAST_CHANGE#

---------- ------------------ ------------

         1            1165820

         2            1165820

         3            1165820

         4            1165820

    由于数据库是打开的状态,所以终止SCN是空,SCN的内容可参考文章:Http://space.itpub.net/23135684/viewspace-627343


SQL> shutdown immediate

数据库已经关闭。

已经卸载数据库。

ORACLE 例程已经关闭。


SQL> startup mount

ORACLE 例程已经启动。

Total System Global Area  313860096 bytes

Fixed Size                  1384352 bytes

Variable Size             155189344 bytes

Database Buffers          150994944 bytes

Redo Buffers                6291456 bytes

数据库装载完毕。


SQL> select file#,checkpoint_change#,fuzzy from v$datafile_header;

     FILE# CHECKPOINT_CHANGE# FUZ

---------- ------------------ ---

         1            1166324 NO

         2            1166324 NO

         3            1166324 NO

         4            1166324 NO

    在正常管理数据库的情况下,FUZZY字段都应该是NO,表示没有模糊不清的SCN存储在数据文件中。

SQL> select file#,checkpoint_change#,last_change# from v$datafile;

     FILE# CHECKPOINT_CHANGE# LAST_CHANGE#

---------- ------------------ ------------

         1            1166324      1166324

         2            1166324      1166324

         3            1166324      1166324

         4            1166324      1166324


    正常关闭数据库的终止SCN应该和启动SCN相同。FUZZY等于NO,且数据库的终止SCN等于启动SCN等于数据文件SCN,那么可以认为数据库是正常关闭,且在打开数据库之前不需要执行实例恢复或Crash恢复。


SQL> alter database open;

数据库已更改。


SQL> shutdown abort

ORACLE 例程已经关闭。


SQL> startup mount

ORACLE 例程已经启动。

Total System Global Area  313860096 bytes

Fixed Size                  1384352 bytes

Variable Size             155189344 bytes

Database Buffers          150994944 bytes

Redo Buffers                6291456 bytes

数据库装载完毕。


SQL> select file#,checkpoint_change#,fuzzy from v$datafile_header;

     FILE# CHECKPOINT_CHANGE# FUZ

---------- ------------------ ---

         1            1166327 YES

         2            1166327 YES

         3            1166327 YES

         4            1166327 YES

    非正常关闭数据库实例,FUZZY字段的值是YES。


SQL> select file#,checkpoint_change#,last_change# from v$datafile;

     FILE# CHECKPOINT_CHANGE# LAST_CHANGE#

---------- ------------------ ------------

         1            1166327

         2            1166327

         3            1166327

         4            1166327

    非正常关闭数据库实例,终止SCN依然为空。那么,在数据库被打开之前必须使用归档Redo日志完成实例恢复或Crash恢复。

以上是“Redo丢失怎么处理”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: Redo丢失怎么处理

本文链接: https://www.lsjlt.com/news/64559.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redo丢失怎么处理
    这篇文章主要介绍Redo丢失怎么处理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一.说明:1.以下所说的当前日志指日志状态为CURRENT,ACTIVE,非当前日志指日志状态为IN...
    99+
    2024-04-02
  • 数据库中redo log丢失怎么办
    这篇文章主要介绍了数据库中redo log丢失怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 数据库版本...
    99+
    2024-04-02
  • redis数据丢失怎么处理
    处理 Redis 数据丢失的方法: 检查 Redis 配置文件:首先检查 Redis 的配置文件是否正确配置了持久化选项,包括 ...
    99+
    2024-04-19
    redis
  • mq数据丢失怎么处理
    当MQ数据丢失时,可以考虑以下几种处理方式:1. 统计丢失数量:首先,可以记录下丢失的数据量和丢失的时间段,以便后续进行分析和处理。...
    99+
    2023-10-20
    mq
  • Redo丢失的4种情况是什么
    这篇文章将为大家详细讲解有关Redo丢失的4种情况是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一.说明:1.以下所说的当前日志指日志状态为CURRENT,ACTI...
    99+
    2024-04-02
  • 怎么解决oracle丢失的是所有的redo日志组问题
    本篇内容主要讲解“怎么解决oracle丢失的是所有的redo日志组问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决oracle丢失的是所有的redo日...
    99+
    2024-04-02
  • redis数据丢失如何处理
    当Redis发生数据丢失时,以下是一些处理方法:1. 定位问题:首先要确定数据确实丢失了,可以通过查看Redis的日志文件来确认是否...
    99+
    2023-09-16
    redis
  • mq消息丢失如何处理
    当MQ消息丢失时,可以考虑以下处理方法: 消息确认机制:在发送消息时,可以要求消息接收方发送一个确认消息来确认已经成功接收到消息...
    99+
    2023-10-26
    mq
  • Beam中数据丢失或重复问题怎么处理
    在Beam中处理数据丢失或重复的问题可以通过以下方法解决: 数据丢失:确保数据源的可靠性和正确性,以避免数据丢失。如果数据源不可...
    99+
    2024-04-02
  • Flume怎么处理数据丢失或重复的情况
    Flume是一个分布式、可靠的日志收集系统,可以保证数据不会丢失或重复。在Flume中,可以通过配置相关的组件来处理数据丢失或重复的...
    99+
    2024-04-02
  • wlanapi.dll丢失怎么办
    如果系统中出现了wlanapi.dll文件丢失的情况,可以尝试以下方法进行修复:1. 重新启动电脑:有时候仅仅是系统出现了临时错误,...
    99+
    2023-09-09
    wlanapi.dll
  • win7启动文件丢失如何处理
    如果在启动过程中发现某个关键的启动文件丢失,可以尝试以下方法进行处理: 启动修复:如果你有一个Windows 7安装光盘或USB...
    99+
    2023-10-22
    win7
  • ac1st16.dll丢失怎么办
    这篇文章主要介绍了ac1st16.dll丢失怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。ac1st16.dll文件修复方法:解压缩下载的文件。  2、复制文件“ac1...
    99+
    2023-06-13
  • msvcp100.dll丢失怎么办
    小编给大家分享一下msvcp100.dll丢失怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!msvcp100.dll丢失的解决方法:首先打开电脑的C盘,并找到windows文件夹打开;然后找到system32文件夹,...
    99+
    2023-06-14
  • Oracle-真实环境的丢失current redo log file的故障恢复
    背景:客户找到我们,反馈有一套10.2.0.4版本的Oracle数据库,运行在Solaris Sparc 10的HA架构上, 因为共享存储被写满与不恰当的操作(这是后来的Sun工程师确认), 导致数据库...
    99+
    2024-04-02
  • ASM Disk丢失怎么办
    这篇文章给大家分享的是有关ASM Disk丢失怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 现象:一台虚拟机强制重启后,ASM磁盘丢失,具体...
    99+
    2024-04-02
  • SQLite3.dll丢失怎么办
    如果您的计算机上缺少SQLite3.dll文件,您可以尝试以下方法解决问题:1. 重新安装相关程序:如果缺失的SQLite3.dll...
    99+
    2023-09-17
    SQL
  • msvcp140.dll丢失怎么办
    这篇文章主要介绍了msvcp140.dll丢失怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。msvcp140.dll丢失的解决方法:首先搜索“控制面板”,找到“程序”并...
    99+
    2023-06-06
  • javascript接收long类型参数时精度丢失怎么处理
    这篇文章主要介绍了javascript接收long类型参数时精度丢失怎么处理的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇javascript接收long类型参数时精度丢失怎么处理文章都会有所收获,下面我们一起...
    99+
    2023-06-27
  • 怎么理解standby redo
    这篇文章主要讲解了“怎么理解standby redo”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么理解standby redo”吧!设定:1.每个sta...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作