oracle错误备忘(ORA-00354,ORA-00353和ORA-00312的处理方法)
昨天根据客户要求,增加了一个jasperreport实现的报表打印功能,然后在测试服务器上测试通过,因为看到测试数据库上的数据都太“旧”了,我就从正式环境下导出了OA系统的数据,导出操作一切顺利,在导入过程中却由于网络问题中断(因为我是远程导入,备份文件在我的机器上)。再次连接数据库,一直报错,说什么只允许内部连接。远程重启了下oracle服务,登录数据库还是不行,发现数据库根本没打开,通过sqlplus执行ORA-00312: 联机日志 1 线程 1:
看情况是日志文件出错,幸好是测试服务器,把我这个对oracle管理一窍不通的家伙急坏了。马上baidu了下错误代码,找到一篇文章:
在日志文件损坏或者dump这些损坏的日志文件的时候,通常回收到类似下面的错误:
ORA-00353: log corruption near block 3740 change 0 time 04/11/2006 13:49:56
或者:
sys@TSMISC02>
这里首先介绍一下oracle使用日志文件的策略。每一个数据库至少有两个或多个日志文件组(),每个组中至少有一个日志成员()。日志文件的主要功能是真实完整的记录对数据库作的全部修改。在出现故障时,如果不能将修改数据永久地写入数据文件,则系统将利用日志前滚来恢复数据库数据文件。日志文件主要是保护数据库以防止故障。
如果至少能够访问一个组内的某一个成员,那么就会对这个组内的可访问成员继续照常进行读写操作,也就是说,将忽略组内的不可用成员。如果在日志切换时无法访问下一个组的所有成员或者损坏的日志文件时改组中日志成员,数据库的正常操作就无法进行了。这也就是常说的,为了防止日志文件的故障或丢失,强烈建议镜象日志,即,在不同磁盘上维护至少两个或多个日志文件()副本的作用——只要组内有一个可用的成员,就会继续“正常”操作。
回到这里,如果数据库发生日志文件的上述损坏,不管是哪种原因造成的,解决方法无外乎是使用完好的文件恢复已经损坏的文件,或者初始化损坏的文件组等等(日志文件的故障处理不做这里的重点介绍,我将会在其他的文章中逐一说明和举例)。
我们这里主要是使用了_disable_logging=true这个隐含参数(实际性能故障诊断时,你可以通过alert.log找到相关信息)造成了归档数据库中,所有日志不能归档,最终数据库不能继续操作的问题,因此解决方法就是:
(a)如果是使用了隐含参数,那么去掉这个隐含参数:
alter system set "_disable_logging"=false scope=both;
(b)然后,初始化损坏的redo log:
alter database clear unarchived logfile '<logilename>';
例如:
sys@TSMISC02> alter system set "_disable_logging"=false scope=both;
sys@TSMISC02> alter database clear unarchived logfile '/oracle/oradata/TSMISC02/redo02.log';
sys@TSMISC02> alter database clear unarchived logfile '/oracle/oradata/TSMISC02/redo03.log';
sys@TSMISC02>
OK,马上执行命令:
再打开数据库,一切正常,重新导入,问题解决。
我需要加强下对oracle基本故障处理方面知识的学习了。
文章转自庄周梦蝶 ,原文发布时间5.17
最后更新:2017-05-17 11:37:02
上一篇:
Oracle数据库的ORA-00257故障解决过程(转载)
下一篇:
准备上班
FrameLayout.xml
Memory network (MemNN) & End to End memory network (MemN2N) & Dynamic memory network
PostgreSQL 10 PostGIS 兼容性 FIX
我国4G标准拓展国际市场取得重要突破
DBA入门之路:学习与进阶之经验谈
文件图片上传
JS中数组排序
Java类集--Map接口、HashMap、IdentityHashMap、SortedMap
Modern Web Identity: Why Your Web Applications Should Be Offering OpenID, OAuth, And Probably Facebook Connect
"太极大师”战不过10秒,武术大师连广场舞大妈都打不过? 武术已成热点话题!