iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >oracle出现ORA-00600错误如何处理
  • 782
分享到

oracle出现ORA-00600错误如何处理

2024-04-02 19:04:59 782人浏览 独家记忆
摘要

小编给大家分享一下oracle出现ORA-00600错误如何处理,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!由于客户现场异常断

小编给大家分享一下oracle出现ORA-00600错误如何处理,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

由于客户现场异常断电,oracle数据库又无法启动了。远程上去看看吧。

  1. 数据库只能mount,已经无法启动

    sql> select status from v$instance;
    STATUS
    ------------
    MOUNTED
    SQL> ALTER DATABASE OPEN;
    ALTER DATABASE OPEN
    *
    ERROR at line 1:
    ORA-01589: must use RESETLOGS or NORESETLOGS option for database open
  2. 尝试recover和resetlogs open都不行

    SQL> recover database;
    ORA-00283: recovery session canceled due to errors
    ORA-01610: recovery using the BACKUP CONTROLFILE option must be done
    SQL> ALTER DATABASE OPEN resetlogs;
    ALTER DATABASE OPEN resetlogs
    *
    ERROR at line 1:
    ORA-01113: file 1 needs media recovery
    ORA-01110: data file 1: 'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF'
  3. Alert log 显示错误

    ~~~~~~~~~~~~~~~~
    Sun Jan 14 19:52:29 2018
    ALTER DATABASE OPEN
    Beginning crash recovery of 1 threads
    parallel recovery started with 3 processes
    ......
    Started redo scan
    Completed redo scan
    read 2300 KB redo, 0 data blocks need recovery
    Errors in file d:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc  (incident=315209):
    ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870], [], [], [], [], [], [], []
    Incident details in: d:\app\oracle\diag\rdbms\prjdb\prjdb\incident\incdir_315209\prjdb_ora_1644_i315209.trc
    Aborting crash recovery due to error 600
    Errors in file d:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc:
    ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870], [], [], [], [], [], [], []
    Errors in file d:\app\oracle\diag\rdbms\prjdb\prjdb\trace\prjdb_ora_1644.trc:
    ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870], [], [], [], [], [], [], []
    ORA-600 signalled during: ALTER DATABASE OPEN...
    ~~~~~~~~~~~~~~~~~~~
  4. 结合ALERT里的错误ORA-00600: internal error code, arguments: [kcratr_nab_less_than_odr], [1], [29904], [4864], [4870],是由于服务器异常断电,导致LGWR写redo log时失败,
    下次重新启动数据库时,需要做实例级恢复,而又无法从联机日志文件里获取到这些redo信息,因为上次断电时,写日志失败了。

  5. 那么ORA-00600的错误里,那几个参数 [1], [29904], [4864], [4870]的含义是,实例需要恢复sequence为29904的redo文件,需要恢复到编号为4870的日志块,而实际上只能恢复到第4864个日志块儿,所以数据库就不能正常启动。

  6. 那我们怎么办呢?先检查一下控制文件和datafile记录的checkpoint_change#信息吧。

数据文件检查点(记录在控制文件中)

SQL> select file#,checkpoint_change#,last_change# from v$datafile where rownum<5;
     FILE# CHECKPOINT_CHANGE# LAST_CHANGE#
---------- ------------------ ------------
         1          664629049
         2          664629049
         3          664629049
         4          664629049

系统检查点(记录在控制文件中)

SQL>  select checkpoint_change# from v$database;
CHECKPOINT_CHANGE#
---------- ------------------ ------------
         664607310

数据文件头检查点(记录在数据文件中)

SQL> select file#,checkpoint_change# from v$datafile_header where rownum<5;
     FILE# CHECKPOINT_CHANGE#
---------- ------------------
         1          664629049
         2          664629049
         3          664629049
         4          664629049

-7. 以上三个checkpoint_change#要一致(只读、脱机表空间除外),数据库才能正常打开。否则会需要进行一步的处理。正常关库时,会生成新的检查点,写入上述三个checkpoint_change#,同时数据文件中的last_change#也会记录下该检查点,也就是说三个checkpoint_change#与last_change#记录着同一个值。

-8. 通过上面的错误,以及checkpoint_change#的不一致,已经可以确认,就是控制文件,由于断电。导致的controlfile损坏(checkpoint_change#不一致)。

-9. 由于没有备份,我们只能通过重建controlfile的方式,来解决这个问题。

指定trace文件的生成路径
SQL&gt; alter database backup controlfile to trace as '/tmp/controlfile.trc';

生成文件提取建库脚本如下,启动数据库到nomount状态,执行下面脚本。
注意:类似的恢复操作,先将现有的数据库进行备份。即使这个数据库已经无法启动。我们也要防止恢复操作导致的更严重的问题。

CREATE CONTROLFILE REUSE DATABASE "PRJDB" NORESETLOGS FORCE LOGGING ARCHiveLOG
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 200
    MAXINSTANCES 8
    MAXLOGHISTORY 584
LOGFILE
  GROUP 1 'D:\APP\ORACLE\ORADATA\PRJDB\REDO01.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 2 'D:\APP\ORACLE\ORADATA\PRJDB\REDO02.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 3 'D:\APP\ORACLE\ORADATA\PRJDB\REDO03.LOG'  SIZE 50M BLOCKSIZE 512
DATAFILE
  'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF',
  'D:\APP\ORACLE\ORADATA\PRJDB\SYSAUX01.DBF',
  'D:\APP\ORACLE\ORADATA\PRJDB\UNDOTBS01.DBF',
  'D:\APP\ORACLE\ORADATA\PRJDB\USERS01.DBF'
CHARACTER SET US7ASCII;

-10. 检查数据库状态

SQL> select status from v$instance;
STATUS
 ------ ----- -
MOUNTED

-11. 尝试重启一下,看到是需要恢复的(其实我是知道这样起不来的,但是就像任性的看看报错)。

SQL> alter database open;
alter database open
*
ERROR at line 1:
ORA-01113: file 1 needs media recovery
ORA-01110: data file 1: 'D:\APP\ORACLE\ORADATA\PRJDB\SYSTEM01.DBF'

-12. 恢复数据库,其实啥也没做,recover就是走个过场,但是必须得走这个流程。

SQL> recover database;
Media recovery complete.
  1. 启动数据库,成功

    SQL> alter database open;
    Database altered.
    SQL> select status from v$instance;
    STATUS
    --- --------
    OPEN
  2. 再看看checkpoint_change#值,统一了吧。

    SQL> select file#,checkpoint_change#,last_change# from v$datafile where rownum<5;
     FILE# CHECKPOINT_CHANGE# LAST_CHANGE#
    ---------- ------------------ ------------
         1          664649053
         2          664649053
         3          664649053
         4          664649053
    SQL> select checkpoint_change# from v$database;
    CHECKPOINT_CHANGE#
    ------------------
         664649053
    SQL> select file#,checkpoint_change# from v$datafile_header where rownum<5;
     FILE# CHECKPOINT_CHANGE#
    ---------- ------------------
         1          664649053
         2          664649053
         3          664649053
         4          664649053

以上是“oracle出现ORA-00600错误如何处理”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: oracle出现ORA-00600错误如何处理

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

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

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

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

下载Word文档
猜你喜欢
  • oracle出现ORA-00600错误如何处理
    小编给大家分享一下oracle出现ORA-00600错误如何处理,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!由于客户现场异常断...
    99+
    2024-04-02
  • Oracle中出现ORA-00600[KZSRGPW]错误怎么办
    这篇文章主要介绍了Oracle中出现ORA-00600[KZSRGPW]错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。环境:DB:...
    99+
    2024-04-02
  • Oracle ORA-00600启动错误
    Oracle为10.2.0.1版本SQL> startup nomount;ORA-00600: internal error code, arguments: [keltnfy-ldmInit], ...
    99+
    2024-04-02
  • oracle中出现ORA-00600内部错误怎么办
    这篇文章给大家分享的是有关oracle中出现ORA-00600内部错误怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。ORA-00600: 内部错误代码, 参数: [kcbn...
    99+
    2024-04-02
  • Oracle中出现ORA-00600内部错误代码怎么办
    这篇文章将为大家详细讲解有关Oracle中出现ORA-00600内部错误代码怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。ORA-00600: 内部错误代码, 参数...
    99+
    2024-04-02
  • 怎么解决Oracle的ORA-00600错误
    这篇文章主要讲解了“怎么解决Oracle的ORA-00600错误”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决Oracle的ORA-00600错误”...
    99+
    2024-04-02
  • ubuntu出现了内部错误如何处理
    当Ubuntu出现内部错误时,您可以按照以下步骤进行处理:1. 报告问题:在Ubuntu系统弹出的内部错误对话框中,选择"...
    99+
    2023-08-29
    ubuntu
  • oracle出现ORA-12705错误怎么办
    小编给大家分享一下oracle出现ORA-12705错误怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Oracle连接sqlplus时连接不上,报如下错误:ORA-12705: Ca...
    99+
    2024-04-02
  • navicat连接mysql出现1045错误如何处理
    这篇文章主要介绍了navicat连接mysql出现1045错误如何处理,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。Navicat连接mysql...
    99+
    2024-04-02
  • oracle中出现ORA-12005错误怎么办
    这篇文章给大家分享的是有关oracle中出现ORA-12005错误怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 Oracle Job ORA-12005 错误的解决 ...
    99+
    2024-04-02
  • Oracle出现ora-12154错误怎么解决
    ORA-12154错误通常表示Oracle客户端无法解析数据库的连接信息。以下是一些常见的解决方法: 确保tnsnames.or...
    99+
    2023-10-23
    Oracle
  • oracle中出现ORA-01502错误怎么办
    小编给大家分享一下oracle中出现ORA-01502错误怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!第一部分: 接到开...
    99+
    2024-04-02
  • oracle中出现ORA-04031错误怎么办
    这篇文章将为大家详细讲解有关oracle中出现ORA-04031错误怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。此问题是sga过小而引起的,首先查看sga大小:s...
    99+
    2024-04-02
  • oracle中出现ORA-65085错误怎么办
    这篇文章主要介绍了oracle中出现ORA-65085错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。SQL> show co...
    99+
    2024-04-02
  • oracle中出现ORA-27101错误怎么办
    这篇文章主要为大家展示了“oracle中出现ORA-27101错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle中出现ORA-27101错误怎...
    99+
    2024-04-02
  • oracle中出现ora-01013错误怎么办
    小编给大家分享一下oracle中出现ora-01013错误怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在测试的过程中发现...
    99+
    2024-04-02
  • oracle中出现ORA-01102错误怎么办
    这篇文章主要介绍了oracle中出现ORA-01102错误怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。测试环境中oracle数据库这...
    99+
    2024-04-02
  • oracle中出现ORA-01122错误怎么办
    小编给大家分享一下oracle中出现ORA-01122错误怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!现象:在做表空间恢复演练时,遇到如下错误提示:SQL> alter da...
    99+
    2024-04-02
  • oracle中出现ORA-600错误怎么办
    这篇文章主要为大家展示了“oracle中出现ORA-600错误怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle中出现ORA-600错误怎么办”这...
    99+
    2024-04-02
  • oracle中出现ORA-28000错误怎么办
    这篇文章给大家分享的是有关oracle中出现ORA-28000错误怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。    这个毛病特别...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作