拨云见日:揭开ORA-00600:[4193]的神秘面纱

墨墨导读:从 Oracle 9i 开始,Oracle引入了一种管理前镜像的新方式。之前的版本是通过 RollBack Segment 进行的,或称为 manual undo(手动 undo)。

Oracle引入回滚段的目的: 1、事务回滚 2、数据库恢复 3、提供读一致性 4、数据库闪回查询(9i引入) 5、利用闪回特性可以恢复。

一、问题表象:

最近客户遇到一个奇怪的问题,oracle数据库大量undo段迟迟不expired, 最终导致undo不够用,引发一系列undo相关报错,关于隐患参数_undo_autotune是false。v$undostat 始终只有一行,数据一直累加,而正常环境应该是5分钟有一条新纪录。多次尝试重建undo没作用,Undo unexpire还是持续上涨, 修改undo_retention为10800(3小时), _highthreshold_undoretention也改为10800,仍然不起作用。


smon在启动后报了报错:

*** 2020-08-11 17:35:57.551SMON: following errors trapped and ignored:ORA-01595: error freeing extent (13934) of rollback segment (168))ORA-00600: internal error code, arguments: [4193], [], [], [], [], [], [], [], [], [], [], []
*** 2020-08-11 17:35:17.268Exception [type: SIGSEGV, Address not mapped to object] [ADDR:0x505E2AE3] [PC:0x981A396, kgegpa()+40] [flags: 0x0, count: 1]DDE previous invocation failed before phase II

当出现断电或硬件故障数据库崩溃或者bug等,通常会发生此问题。启动时,数据库先进行正常的前滚(重做),然后再进行回滚(撤消),这是在回滚时生成错误的地方。

根据官方文档:ORA-600 [4193] “seq# mismatch while adding undo record” (Doc ID 39282.1)的描述,在重做记录和回滚记录之间检测到不匹配。

  Format: ORA-600 [4193] [a] [b]VERSIONS:  versions 6.0 to 12.1
DESCRIPTION:
  A mismatch has been detected between Redo records and Rollback (Undo)  records.
  We are validating the Undo block sequence number in the undo block against  the Redo block sequence number relating to the change being applied.
  This error is reported when this validation fails.
ARGUMENTS:  Arg [a] Undo record seq number  Arg [b] Redo record seq number

常规情况,可以通过重建undo来解决,可以参考文档:Step by step to resolve ORA-600 4194 4193 4197 on database crash (Doc ID 1428786.1)

Best practice to create a new undo tablespace.This method includes segment check.
1. Create pfile from spfile to editSQL> Create pfile='/tmp/initsid.ora' from spfile;
2. Shutdown the instance
3. set the following parameters in the pfile /tmp/initsid.ora    undo_management = manual    event = '10513 trace name context forever, level 2'
4. SQL>>startup restrict pfile='/tmp/initsid.ora'
5. SQL>select tablespace_name, status, segment_name from dba_rollback_segs where status != 'OFFLINE';
If all offline then continue to the next step
6. Create new undo tablespace - exampleSQL>create undo tablespace
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java.sql.SQLException: ORA-00600是一种Oracle数据库的内部错误,表示数据库管理系统遇到了一个未处理的异常状况。这种错误通常是由于软件错误、数据库损坏或操作系统问题引起的。ORA-00600错误是Oracle自动收集的错误,并被记录在数据库的错误日志文件中。 ORA-00600错误的解决方法通常是联系Oracle支持团队,以获取专业的帮助和支持。这些专家可以研究错误日志文件,并根据其中的信息来提供具体的解决方案。他们可能会要求提供详细的错误描述、错误日志文件的副本以及可能的重现步骤,以便更好地了解问题。 此外,有一些常见的解决方法可以尝试,如重新启动数据库实例、使用Oracle提供的修复程序或打补丁、检查数据库的一致性和完整性、恢复备份等。然而,这些方法都需要在与Oracle支持团队的沟通和指导下进行,以确保正确性和有效性。 总之,ORA-00600错误是一种内部错误,通常需要通过联系Oracle支持团队来解决。及时记录错误信息、提供相关文件以及与专家合作,可以有效地诊断和解决这个问题,确保数据库的稳定性和可靠性。 ### 回答2: ORA-00600是Oracle数据库中的一种错误代码,通常表示出现了内部错误。这种错误是由于数据库在执行某个操作时发现了一些与其内部逻辑不符的情况导致的。 有几种可能的原因会引发ORA-00600错误,包括: 1. 数据库软件中的一个或多个bug。 2. 用户执行了一些非法操作或使用了不符合规范的语法。 3. 数据库实例配置不正确或损坏。 4. 物理数据库文件损坏或不一致。 解决ORA-00600错误的方法通常是: 1. 查找并应用相关的Oracle补丁程序。Oracle官方经常发布相关的补丁程序,以修复已知的bug。 2. 更新Oracle数据库软件版本。如果该错误是由于已知的bug引起的,升级到一个已修复该问题的版本可能会解决该问题。 3. 检查和修复数据库实例的配置问题。确保数据库参数设置正确且不冲突,并根据需要进行更改。 4. 运行Oracle提供的诊断工具,如ORA-600和ORA-7445错误报告工具,获得更多关于错误的详细信息和建议的解决方案。 5. 恢复损坏的数据库文件。如果数据文件损坏导致ORA-00600错误,可以尝试使用Oracle提供的工具来修复或恢复这些文件。 总之,ORA-00600错误通常是由于Oracle数据库内部的问题引起的。解决该错误的方法可能因情况而异,但可以尝试应用补丁、更新软件版本、检查配置并修复损坏的文件等来解决该问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值