ORA-03113的解决方案

笔者日前遇到服务器断电后oracle数据库崩溃的问题,在按照网上教程修复时发现,有关于报错ora-03113的解决方案混乱且不起作用。笔者在总结了前人的博客并结合在修复中遇到的问题,总结了一份较为全面的解决方案,有不足之处敬请补充。

一、查看日志

1.定位日志位置

此步骤最为重要,笔者在浏览大部分解决方案时上来就是说的解决办法,并未梳理排查步骤。实际工作中针对某一报错可能有十几种原因,盲目套用万能解决方案有时候会错上加错。此处笔者介绍oracle 11g以上的版本的日志位置。

默认情况下,oracle的日志文件记录在$ORACLE/rdbms/log目录下,一般来说默认路径为:

bash 复制代码
/oracle/oracle/diag/rdbms/rac/rac1/trace
/oracle/oracle/diag/rdbms/rac/rac1/alert

具体路径需要根据安装位置等自行调整,如笔者的示例数据库就在,此路径是安装orcl时设置的全局数据库名称,每个人安装习惯不同,路径有所不同。

bash 复制代码
diag/rdbms/orcl/orcl/trace


2.查看日志文件

根据控制台报错找到对应的报错日志文件,使用txt打开即可。根据控制台报错的log编号找到对应trc文件。例:Orc-ora-2854文件。

一般只需要从后向前看最新的报错记录信息即可。这里笔者根据此错误总结了几个常见的报错,包括

1.归档日志空间不足,一般表现日志表现为ORA-19815: 警告:

bash 复制代码
db_recovery_file_dest_size 字节 (共 4102029312 字节) 已使用 100.00%, 尚有 0 字节可用。

2.控制文件版本号不一致,如下图所示。

3.如有其他原因请自行百度

二、解决办法

1.归档日志空间不足

针对归档日志空间不足,解决办法分为两步,

一、删除原有的归档日志释放空间

1.使用rman工具,win+r+cmd打开cmd输入以下命令,删除7天前的归档日志。

bash 复制代码
rman target
RMAN> delete noprompt archivelog until time "sysdate-7";

2.此处添加几条备用的命令,可供读者选择

检查归档日志

bash 复制代码
crosscheck archivelog all;

删除所有过期归档日志

bash 复制代码
delete expired archivelog all;

二、修改归档日志空间的大小(扩容)

win+r+cmd打开cmd输入以下命令登录数据库。

c 复制代码
sqlplus / as sysdba

输入以下命令,此处设置归档日志大小为4g,可根据实际进行调整。为不影响复制,没有添加注释,有需要的可以自行百度含义。

bash 复制代码
SQL> startup mount  
SQL> conn / as sysdba  
SQL> select * from v$recovery_file_dest;  
SQL> alter system set db_recovery_file_dest_size=4G;
SQL> alter database open;  

完成后重启即可解决问题。

2.控制文件版本号不一致

1.首先尝试修复控制文件。

通过RMAN命令。一般数据库控制文件位于\app\chadmini\oradata\orcl目录下,在cmd中按照命令依次恢复,此处路径需要根据控制文件的位置调整。

bash 复制代码
rman target
rman>shutdown immediate
startup nomount
Restorecontrolfile from 'D:\app\chadmini\oradata\orcl\CONTROL01.CTL'

完成以上操作后,对数据库进行重启,如还是无法启动,可以确认当前所有控制文件均出现问题,开始重建控制文件。

2.重建控制文件

重建控制文件,按照以下步骤重建,重建前对文件进行备份。笔者控制文件位于D:\app\chadmini\oradata\orcl下,数据库文件名称WXSL.DBF为故下方命令均以此目录为示范。其中文件及路径根据具体数据库文件调整,重建完成后重新启动数据库,重新配置监听即可。对应的数据库文件和名称如图所示。

按照以下命令逐步执行,注意;即命令结束的位置。

bash 复制代码
sqlplus /NOLOG;
conn / as sysdba;
shutdown immediate;
startup nomount;
CREATE CONTROLFILE REUSE DATABASE "orcl" NORESETLOGS NOARCHIVELOG
            MAXLOGFILES 16
            MAXDATAFILES 100
            MAXINSTANCES 2
            MAXLOGHISTORY 453
            LOGFILE
            GROUP 1'D:\app\chadmini\oradata\orcl\REDO01.LOG' SIZE 50M,
            GROUP 2'D:\app\chadmini\oradata\orcl\REDO02.LOG' SIZE 50M,
            GROUP 3'D:\app\chadmini\oradata\orcl\REDO03.LOG' SIZE 50M
            DATAFILE
            'D:\app\chadmini\oradata\orcl\WXSL.DBF',
            'D:\app\chadmini\oradata\orcl\SYSAUX01.DBF',
            'D:\app\chadmini\oradata\orcl\SYSTEM01.DBF',
            'D:\app\chadmini\oradata\orcl\UNDOTBS01.DBF',
            'D:\app\chadmini\oradata\orcl\USERS01.DBF'
            CHARACTER SET ZHS16GBK;
			
recover database;
Alter database open;
alter tablespace temp
            add tempfile'D:\app\chadmini\oradata\orcl\TEMP01.DBF'
            SIZE 200M REUSE AUTOEXTEND ON MAXSIZE 5G;
相关推荐
ヾChen2 小时前
头歌MySQL——复杂查询
数据库·物联网·学习·mysql·头歌
老虎06272 小时前
黑马点评学习笔记07(缓存工具封装)
笔记·学习·缓存
上下翻飞的屁3 小时前
jdbcTemplate执行sql后数据库字段没有更新问题解决
java·数据库·sql
悦光阴3 小时前
SQL Server 并发控制:Fabric Warehouse只支持快照隔离
大数据·运维·数据库·fabric
谅望者3 小时前
SQL子查询完全指南:从零掌握嵌套查询的三种用法与最佳实践
数据库·sql·数据库开发·子查询
大邳草民3 小时前
深入理解 Python 的“左闭右开”设计哲学
开发语言·笔记·python
阿萨德528号3 小时前
Redis 分布式锁进阶:跨语言场景下的锁兼容性与一致性保障
数据库·redis·分布式
im_AMBER3 小时前
React 12
前端·javascript·笔记·学习·react.js·前端框架
开开心心就好3 小时前
电脑音质提升:杜比全景声安装详细教程
java·开发语言·前端·数据库·电脑·ruby·1024程序员节