暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

(ORA-00214)-undo表空间文件损坏

原创 huawei 2021-03-02
2111

(ORA-00214)-undo表空间文件损坏

现象描述

数据库所在机器异常断电导致启动失败,系统显示如下错误信息:
ORA-00214: control file '/opt/oracle/db/oradata/iptvmdn/lv_control2tbs' version
117553 inconsistent with file '/opt/oracle/db/oradata/iptvmdn/lv_control1tbs'

可能原因

异常断电导使undo表空间文件损坏,数据库启动失败。

处理步骤

  1. oracle用户登录数据库所在机器。
  2. sysdba用户连接数据库。

    % sqlplus / as sysdba

  3. 通过spfile文件创建一个临时的pfile文件。

    SQL> create pfile=’$ORACLE_HOME/dbs/temp_pfile_ora’ from spfile;

  4. 退出sqlplus。

    SQL> quit

  5. 在该pfile文件最后添加*.undo_management='MANUAL'。

    % vi $ORACLE_HOME/dbs/temp_pfile_ora

    在此文件最后添加*.undo_management='MANUAL'
    说明:
    在MANUAL模式无法切换undo表空间。
  6. sysdba用户连接数据库。

    % sqlplus / as sysdba

  7. 使用临时pfile文件启动数据库。

    SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;

    说明:
    如果还是无法启动数据库,可以将表空间文件offline,请参见(ORA-01157、ORA-01110)-Oracle表空间文件被删除
    数据库启动成功,显示如下信息。
    ORACLE instance started.
    
    Total System Global Area 4142166016 bytes
    Fixed Size                  2166208 bytes
    Variable Size            2214593088 bytes
    Database Buffers         1912602624 bytes
    Redo Buffers               12804096 bytes
    Database mounted.
    Database opened.
  8. 查看并记录回滚段信息。

    SQL> select SEGMENT_NAME from dba_rollback_segs;

  9. 关闭数据库。

    SQL> shutdown immediate

  10. 修改临时pfile文件。
    1. 删除“*.undo_management='MANUAL'”
    2. 添加如下内容。

      _corrupted_rollback_segments=(_SYSSMU1_1192403689$,_SYSSMU2_1192403689$,_SYSSMU3_1192403689$,_SYSSMU4_1192403689$,_SYSSMU5_1192403689$,_SYSSMU6_1192403689$,_SYSSMU7_1192403689$,_SYSSMU8_1192403689$,_SYSSMU9_1192403689$,_SYSSMU10_1192403689$)

      括号中的内容为8中的查询结果。

  11. 使用临时pfile文件启动数据库。

    SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;

    启动成功,系统显示如下信息:
    ORACLE instance started.
    
    Total System Global Area 4142166016 bytes
    Fixed Size                  2166208 bytes
    Variable Size            2214593088 bytes
    Database Buffers         1912602624 bytes
    Redo Buffers               12804096 bytes
    Database mounted.
    Database opened.
  12. 重建undo表空间。

    SQL> CREATE UNDO TABLESPACE undotbs02 DATAFILE ‘/var/tmp/cssd_mdn/myundo.dbf' SIZE 2G;

    SQL> alter system set undo_tablespace = undotbs2;

    SQL> drop tablespace UNDOTBS1 including contents cascade constraints;

    SQL> CREATE UNDO TABLESPACE undotbs01 DATAFILE ‘/dev/oramdn_dg/lv_undotbs’ size 9G;

    SQL> autoextentd off;

    SQL> alter system set undo_tablespace = UNDOTBS1;

  13. 关闭数据库。

    SQL> shutdown immediate;

  14. 重启数据库。

    SQL> startup

    启动成功,系统显示如下信息:
    OORACLE instance started.
    
    Total System Global Area 4142166016 bytes
    Fixed Size                  2166208 bytes
    Variable Size            2214593088 bytes
    Database Buffers         1912602624 bytes
    Redo Buffers               12804096 bytes
    Database mounted.
    Database opened.

    如果问题没有解决,请联系华为技术工程师。

建议与总结

Oralce数据库尽量不要强行断电。控制文件、参数文件一定要做好备份。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论