天萃荷净

运维DBA反映Oracle数据库在启动时报错ORA-00313 ORA-00312 ORA-27037,分析原因为数据库redo联机日志文件损坏导致

环境模拟

删除状态为active的联机日志,然后强行关闭数据库

1.数据库报错ORA-00313 ORA-00312 ORA-27037

SQL> startup

ORACLE instance started.

Total System Global Area 167772160 bytes

Fixed Size 1260720 bytes

Variable Size 142607184 bytes

Database Buffers 16777216 bytes

Redo Buffers 7127040 bytes

Database mounted.

ORA-00313: open failed for members of log group 1 of thread 1

ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’

ORA-27037: unable to obtain file status

Linux Error: 2: No such file or directory

Additional information: 3

Alert.log 日志中错误

Wed Aug 24 00:26:33 2011

Errors in file /u01/admin/xienfei/udump/xff_ora_9186.trc:

ORA-00313: open failed for members of log group 1 of thread 1

ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’

ORA-27037: unable to obtain file status

Linux Error: 2: No such file or directory

Additional information: 3

xff_ora_9186.trc文件中错误

ORA-00313: open failed for members of log group 1 of thread 1

ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’

ORA-27037: unable to obtain file status

Linux Error: 2: No such file or directory

Additional information: 3

查询当前日志组状态

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;

GROUP# STATUS MEMBER

———- —————- ———————————————

1 CURRENT /u01/oradata/xienfei/redo01.log

3 INACTIVE /u01/oradata/xienfei/redo03.log

2 ACTIVE /u01/oradata/xienfei/redo02.log

2.尝试删除redo日志

SQL> alter database drop logfile group 1;

alter database drop logfile group 1

*

ERROR at line 1:

ORA-01623: log 1 is current log for instance xff (thread 1) – cannot drop

ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’

发现是当前日志不能被删除,尝试切换日志

SQL> alter system switch logfile;

alter system switch logfile

*

ERROR at line 1:

ORA-01109: database not open

在数据库未打开状态,不能切换日志,只能尝试清空日志

SQL> alter database clear unarchived logfile group 1;

alter database clear unarchived logfile group 1

*

ERROR at line 1:

ORA-01624: log 1 needed for crash recovery of instance xff (thread 1)

ORA-00312: online log 1 thread 1: ‘/u01/oradata/xienfei/redo01.log’

因为数据库恢复需要使用,不能被清空,尝试不完成恢复

SQL> recover database until cancel;

ORA-00279: change 1272687 generated at 08/24/2011 00:20:05 needed for thread 1

ORA-00289: suggestion : /u01/archive/1_27_756841839.arc

ORA-00280: change 1272687 for thread 1 is in sequence #27

Specify log: {=suggested | filename | AUTO | CANCEL}

auto

ORA-00279: change 1272903 generated at 08/24/2011 00:25:17 needed for thread 1

ORA-00289: suggestion : /u01/archive/1_28_756841839.arc

ORA-00280: change 1272903 for thread 1 is in sequence #28

ORA-00278: log file ‘/u01/archive/1_27_756841839.arc’ no longer needed for this

recovery

ORA-00308: cannot open archived log ‘/u01/archive/1_28_756841839.arc’

ORA-27037: unable to obtain file status

Linux Error: 2: No such file or directory

Additional information: 3

ORA-01547: warning: RECOVER succeeded but OPEN RESETLOGS would get error below

ORA-01194: file 1 needs more recovery to be consistent

ORA-01110: data file 1: ‘/u01/oradata/xienfei/system01.dbf’

已经提示数据不一致,尝试着打开数据库

SQL> alter database open resetlogs;

alter database open resetlogs

*

ERROR at line 1:

ORA-01194: file 1 needs more recovery to be consistent

ORA-01110: data file 1: ‘/u01/oradata/xienfei/system01.dbf’

创建pfile文件,添加隐含参数,使之不进行检查点一致性校验

SQL> create pfile=’/tmp/pfile’ from spfile;

File created.

修改pfile ,添加以下参数

*._allow_resetlogs_corruption=TRUE

*._allow_error_simulation=TRUE

SQL> shutdown abort

ORACLE instance shut down.

使用pfile打开数据库

SQL> startup pfile=’/tmp/pfile’

ORACLE instance started.

Total System Global Area 167772160 bytes

Fixed Size 1260720 bytes

Variable Size 150995792 bytes

Database Buffers 8388608 bytes

Redo Buffers 7127040 bytes

Database mounted.

ORA-38760: This database instance failed to turn on flashback database

发现flashback导致数据库不能被正常打开,尝试关闭它

SQL> alter database flashback off;

Database altered.

尝试直接open数据库

SQL> alter database open;

alter database open

*

ERROR at line 1:

ORA-01589: must use RESETLOGS or NORESETLOGS option for database open

根据提示,使用resetlogs打开数据库

SQL> alter database open resetlogs;

Database altered.

查询日志状态

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;

GROUP# STATUS MEMBER

———- —————- ———————————————

3 UNUSED /u01/oradata/xienfei/redo03.log

2 UNUSED /u01/oradata/xienfei/redo02.log

1 CURRENT /u01/oradata/xienfei/redo01.log

因为group1错误,而当前日志组在group 1上,所以切换日志组

SQL> alter system switch logfile;

System altered.

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;

GROUP# STATUS MEMBER

———- —————- ———————————————

3 UNUSED /u01/oradata/xienfei/redo03.log

2 CURRENT /u01/oradata/xienfei/redo02.log

1 ACTIVE /u01/oradata/xienfei/redo01.log

SQL> alter system checkpoint;

System altered.

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;

GROUP# STATUS MEMBER

———- —————- ———————————————

3 UNUSED /u01/oradata/xienfei/redo03.log

2 CURRENT /u01/oradata/xienfei/redo02.log

1 INACTIVE /u01/oradata/xienfei/redo01.log

4.删除有问题的group 1日志组

SQL> alter database drop logfile group 1;

Database altered.

SQL> alter system switch logfile;

System altered.

添加日志组并检查是否正确

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;

GROUP# STATUS MEMBER

———- —————- ———————————————

3 CURRENT /u01/oradata/xienfei/redo03.log

2 ACTIVE /u01/oradata/xienfei/redo02.log

SQL> alter database add logfile group 1 ‘/u01/oradata/xienfei/redo01.log’ size 50m reuse;

Database altered.

SQL> alter system switch logfile;

System altered.

SQL> select a.group#,a.status,b.member from v$log a,v$logfile b where a.group#=b.group#;

GROUP# STATUS MEMBER

———- —————- ———————————————

3 ACTIVE /u01/oradata/xienfei/redo03.log

2 ACTIVE /u01/oradata/xienfei/redo02.log

1 CURRENT /u01/oradata/xienfei/redo01.log

注意:根据oracle官方建议,使用oracle隐含参数运行数据库可能存在很多不稳定因素,建议立即导出数据库数据,然后新建库,重新导入数据

--------------------------------------ORACLE-DBA----------------------------------------

最权威、专业的Oracle案例资源汇总之【案例】Oracle报错ORA-00313 ORA-00312 ORA-27037当前联机日志损坏恢复

Oracle当前日志组出错,【案例】Oracle报错ORA-00313 ORA-00312 ORA-27037当前联机日志损坏恢复...相关推荐

  1. oracle加as报错,【Oracle】-【sqlplus / as sysdba登录报错问题】-新用

    [Oracle]-[sqlplus / as sysdba登录报错问题]-新用户使用sqlplus / as sysdba登录报错解决 [Oracle]-[sqlplus / as sysdba登录报 ...

  2. linux oracle 11g x86,Oracle 11g在Linux6下安装及报错 C [ld-linux-x86-64.so.2+0x14d70]的解决方...

    Oracle 11g在Linux6下安装及报错 C [ld-linux-x86-64.so.2+0x14d70]的解决方法 首页 → 数据库技术 背景: 阅读新闻 Oracle 11g在Linux6下 ...

  3. 深圳坐标软件 SQL数据库 复制 报错 MS-DOS 功能无效 上读取失败 1(函数不正确) 恢复实践

    坐标软件 SQL数据库 复制 报错 MS-DOS 功能无效 上读取失败 1(函数不正确) 恢复实践 接到文件,立即组织进行分析工作,发现 select * from sysobjects  --系统表 ...

  4. asm 查看 数据文件 修改 时间_ASM磁盘组ORA15042故障处理案例一:NORMAL磁盘组下失败组离线后ORA15042报错的处理...

    点击上方蓝字关注我们- 我们的文章会在微信公众号"Oracle恢复实录"和博客网站"rescureora.com" 同步更新 ,欢迎关注收藏,也欢迎大家转载,但 ...

  5. Oracle GoldenGate Monitor agent安装后的报错OGGMON-20603

    问题现象:Oracle GoldenGate Monitor agent正常安装后,info all中查看JAGENT 进程已经存在,进程也可以正常启动,但是OEM的OGG插件自动搜索始终无法搜索到O ...

  6. oracle在服务器断电重启后启动报错ORA-00600: internal error code, arguments: [kcm_headroom_warn_1], []

    一.错误场景介绍. 数据库:11.2.0.4(单实例,没有任何备份) 系统:Centos 6.5(虚拟机) 由于机房断电导致oracle数据库(单实例)所在服务器的虚拟服务器出现问题,在经过恢复后虚拟 ...

  7. oracle 未明确列义,案例:Oracle缺少同义词DDL语句无法执行 ORA-00604 ORA-00942

    天萃荷净 在执行DDL语句时无法执行,报错ORA 00604 ORA 00942,通过隐含参数来解决同义词问题 在最近的一个客户案例中,因为缺少dual同义词,导致ddl语句无法执行.这里_syste ...

  8. oracle数据泵导入分区表统计信息报错(一)

    今天在进行数据泵导入操作时,发现一个bug. 数据库版本Oracle 10203 for Solaris RAC,执行导入在处理表的统计信息时报错,错误信息为:ORA-39083和ORA-917. 经 ...

  9. linux 下 oracle 10.2.0.1 32bit netca报错

    现象如下: 今天一同事安装完数据库软件运行netca创建监听时报错(运行netmgr与dbca均可执行成功),  报错信息: [oracle@WEB01A bin]$ netca   Oracle N ...

最新文章

  1. 搭建LoadRunner中的场景(三)场景的执行计划
  2. TCP/IP协议模型详解
  3. 安装上 Octotree 插件让你更加方便的阅读 gitHub 中的代码
  4. bond4 交换机配置_Linux--多网卡的7种Bond模式和交换机配置
  5. MATLAB——SRTM DEM显示
  6. php时间戳防盗链,七牛云储存CDN时间戳防盗链PHP获取方法
  7. tftp拷贝linux文件夹,CentOS下使用TFTP向目标板传送文件
  8. FPGA使用ISERDES2过采样
  9. Mina MEID/GSM Activator 1.0 三网信号激活,支持12.5.3~14.7
  10. 『运维自媒体联盟』限时特供学习资源大礼包
  11. 美不胜“售”的花花世界
  12. pytorch1.13启用caffe2
  13. 2018/3/6-2018/3/10
  14. IT系统管理员的节日
  15. 电商项目业务整体概览
  16. catia打开后拖动工具栏有残影_Catia如何恢复工具栏布局
  17. h1283 linux内核,H1073C H1073 H1283升级失败恢复方法
  18. 基于java基于微服务架构的设备管理系统的设计与实现计算机毕业设计源码+系统+lw文档+mysql数据库+调试部署
  19. windows和Linux分区相互访问
  20. 数字集成电路课程作业

热门文章

  1. MES制造执行系统设计与开发
  2. windows系统下文件批量重命名方法
  3. IPGuard如何注册
  4. Python中的魔术方法详解
  5. 图像二值化_三角阈值法
  6. 在deepin中安装longman英语字典第五版
  7. vs2015启动网站调试提示 HTTP 错误 403.14 - Forbidden Web 服务器被配置为不列出此目录的内容。 解决方法
  8. oracle执行存储过程参数,Oracle 执行存储过程四种方法(带参数 不带参数)
  9. Xilinx FPGA平台GTX简易使用教程(二)GTX时钟篇
  10. c语言按字节翻转无符号整数,C语言将一个无符号整数转换为任意d进制