一.故障描写叙述

首先是实例恢复须要用到的REDO文件损坏

二、解决方法

1.对于非当前REDO或者当前REDO可是无活动事务使用下面CLEAR命令:

用CLEAR命令重建该日志文件SQL>alter database clear logfile group 3。

假设是该日志组还没有归档,则须要用SQL>alter database clear unarchived logfile group 3;

由于是当前实例恢复须要用的REDO,且未归档。使用是CLEAR命令不行的。

2.没备份,有备份能够參考下面:

拷贝有效的数据库的全备份,并不全然恢复数据库

能够採用获取近期的SCN的办法用until scn恢复或用until cnacel恢复

recover database until cancel

  先选择auto。尽量恢复能够利用的归档日志。然后又一次

recover database until cancel

这次输入cancel,完毕不全然恢复,也就是说恢复两次。如:

SQL> recover database until cancel;

Auto

……

SQL> recover database until cancel;

Cancel;

、利用alter database open resetlogs打开数据库

说明:

这样的办法恢复的数据库是一致的不全然恢复。会丢失当前联机日志中的事务数据

这样的方法适合于归档数据库而且有可用的数据库全备份。

恢复成功之后,记得再做一次数据库的全备份。

建议联机日志文件一定要实现镜相在不同的磁盘上,避免这样的情况的发生,由于不论什么数据的丢失对于生产来说都是不容许的。

3.改动隐含參数_allow_resetlogs_corruption

_allow_resetlogs_corruption=TRUE

又一次启动数据库,利用until cancel恢复

SQL>recover database until cancel;

Cancel

假设出错,不再理会,发出

SQL>alter database open resetlogs;

数据库被打开后,立即运行一个full export

shutdown数据库,去掉_all_resetlogs_corrupt參数

二、參考EYGLE:ORA-00600 kcratr1_lostwrt之解决与原理分析

ksedmp: internal or fatal error

ORA-00600: internal error code, arguments: [kcratr1_lostwrt], [], [], [], [], [], [], []

Current SQL statement for this session:

alter database open

这个错误不难解决,可是其详细成因有点意思。

Metalink对这个错误的解释仅仅有一句关键:

When an instance is restarted following an instance crash, Oracle carries out some checks against the last block that was written to disk prior to the instance crash.

If Oracle finds an old block, then this suggests a lost write and the  error is raised.

这句话是说,当实例崩溃之后启动,Oracle会去检查崩溃前最后一个写出的数据块,通过控制文件校验其是否一致,假设这个块是Old的,则说明最后的写操作丢失了。



这是一个很快捷巧妙地推断。假设有写丢失,自然必须引入恢复。

在跟踪文件里记录了具体的信息:

Last BWR afn: 6 rdba: 0x18f9590(blk 1021328) ver: 0x0001.5c21fd6e.01 flg: 0x04

Disk version: 0x0001.5c1ec4f0.04 flag: 0x04

提示说。控制文件记录的最后一次写的数据块是file6 block 1021328,SCN版本号为:5c21fd6e,而数据文件上记录的SCN则是5c1ec4f0,后者Old,小于前者,这说明丢失了写操作。



那是否能恢复呢?跟踪文件中还会记录这种信息:

Thread checkpoint rba:0x00dfeb.00000002.0010 scn:0x0001.5c1ee5b7

On-disk rba:0x00dfeb.0001161f.0000 scn:0x0001.5c2266d6

线程检查点的SCN为5c1ee5b7。而On-Disk Rba的SCN为5c2266d6,全然能够推演超过5c21fd6e,能够恢复。



所以这种问题:

SQL>startup mount;

SQL>recover database;

SQL>alter database open;

一般就能够完毕恢复了。假设不幸的,你的On-Disk Rba不足以恢复丢失的写操作。则问题将严重了。

參考:http://blog.itpub.net/25964700/viewspace-709097/      http://www.eygle.com/archives/2010/05/ora-00600_kcratr1_lostwrt.html

简单记录一次REDO文件损坏报错 ORA-00333重做日志读取块出错的更多相关文章

  1. 【svn】在提交文件是报错:previous operation has not finished;run 'cleanup' if it was interrupted

    1.svn在提交文件是报错:previous operation has not finished;run 'cleanup' if it was interrupted2.原因,工作队列被占用,只需 ...

  2. R.java 文件内报错:Underscores can only be used with source level 1.7 or greater。

    R.java 文件内报错:Underscores can only be used with source level 1.7 or greater 网上查找后得知是Android工程图片资源命名的问 ...

  3. 如何快速解决myeclipse中导入jquery文件的报错。

    如何快速解决myeclipse中导入jquery文件的报错. 解决: 选中错误的文件, 点击右键, 选中myeclipse,点击Exclude From Validation.

  4. Python读取CSV文件,报错:UnicodeDecodeError: 'gbk' codec can't decode byte 0xa7 in position 727: illegal multibyte sequence

    Python读取CSV文件,报错:UnicodeDecodeError: 'gbk' codec can't decode byte 0xa7 in position 727: illegal mul ...

  5. 导入文件 服务器报错,有可能是 开发时候是window 服务器是linux,两个系统的文件系统的/和\是相反的,要注意这块

    导入文件 服务器报错,有可能是 开发时候是window 服务器是linux,两个系统的文件系统的/和\是相反的,要注意这块

  6. java -- SSM配置完成后,能访问jsp文件不能访问html文件,报错解析

    SSM配置完成后,能访问jsp文件不能访问html文件,报错解析 在确保路径没有任何问题的,情况下,相同的页面,jsp能够正常访问,html却不能正常访问(404). 解决方法: 在web.xml中添 ...

  7. drop redo logfile current报错

    目的:在安装完毕11.2.0.4版本Oracle单实例数据库后,对日志进行格式化,删除原日志组current状态,删除报错 #对于理论学习,而带来的理解命令,因此作为记录 #查询日志状态SYS > ...

  8. spark.read.csv读取CSV文件 ArrayIndexOutOfBoundsException报错

    通过 spark.read.csv读取CSV文件时,遇到 到 ArrayIndexOutOfBoundsException报错,初步判断是缺少参数导致,放百度看看,没找引起问题相关的参数. 第一个看到 ...

  9. python引用py文件中文报错

    文件 a.py 中引用文件 b.py 如果文件b.py中包含中文,会报错. 文件hello.py中代码如下: def say_nihao(): print "你好" 文件main. ...

随机推荐

  1. C语言静态库与动态库(Windows下测试)

    转载于:https://zhidao.baidu.com/question/1946953913764139388.html,原文为Linux上测试,本文为在Windows上编译测试 我们通常把一些公 ...

  2. UNIX系统高级编程——第六章-系统数据文件和信息-总结

    口令文件: /* The passwd structure. */ struct passwd { char *pw_name; /* Username. */ char *pw_passwd; /* ...

  3. Unity shader UI的3D效果

    原创,转载请标明出处 1.效果 scene视图中的效果: game视图中效果: 2.核心思想:改变UI的顶点坐标 3.好处:可以用正交相机来实现3D效果. 4.Shader 实现 // Unity b ...

  4. dashboard安装

    1,安装程序包 # yum install -y openstack-dashboard 2,修改配置文件 # vim /etc/openstack-dashboard/local_settings ...

  5. Fiddler(Web/HTTP调试利器)

    简述 Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的"进出"Fiddler的数据(指cookie.htm ...

  6. deeplink技术的两篇资料

    两篇资料如下: https://zhuanlan.zhihu.com/p/20694818?refer=ouyangchen http://www.sohu.com/a/122694049_49134 ...

  7. 安卓开发--WebView

    package com.zhangxi.test01; import android.app.Activity;import android.app.ProgressDialog;import and ...

  8. BZOJ 3209 数位DP

    思路: 先预处理出来组合数 按位做 枚举sum[x]是多少 注意Mod不是一个质数 //By SiriusRen #include <cstdio> using namespace std ...

  9. jsp输出当前时间

    在jsp页面中输出完整的时间,格式为"年 月 日  时:分:秒" <% Date date = new Date(); SimpleDateFormat t = new Si ...

  10. NSStream 流式思想

    流式思想的本质是将数据或信号看作流.流的管理者NSStream看作管道. 内容包含两方面: 1.流的建立:源.目的地: 2.流的管理:状态事件与数据事件. 本质上是建立联系.处理数据.处理状态.