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;
相关推荐
EniacCheng3 分钟前
【RUST】学习笔记-整型
笔记·学习·rust
大猫和小黄5 分钟前
若依微服务全面适配PostgreSQL-OpenGauss数据库
数据库·微服务·postgresql·若依
断剑zou天涯9 分钟前
【算法笔记】树状数组IndexTree
java·笔记·算法
老徐电商数据笔记12 分钟前
技术复盘第二篇:电商数据主题域划分企业级实践
大数据·数据库·数据仓库·零售·教育电商·技术面试
jfqqqqq13 分钟前
postgres查询、重设自增序列的起始值
数据库·sql·postgres·自增序列
22 分钟前
TIDB——PD(placement Driver)
java·数据库·分布式·tidb·
DemonAvenger28 分钟前
Redis与MySQL双剑合璧:缓存更新策略与数据一致性保障
数据库·redis·性能优化
断春风40 分钟前
如何避免 MySQL 死锁?——从原理到实战的系统性解决方案
数据库·mysql
闲人编程41 分钟前
基础设施即代码(IaC)工具比较:Pulumi vs Terraform
java·数据库·terraform·iac·codecapsule·pulumi
北岛寒沫42 分钟前
北京大学国家发展研究院 经济学辅修 经济学原理课程笔记(第九课 公共产品与公共资源)
经验分享·笔记