首页  >  文章  >  数据库  >  异常断电导致ORACLE控制文件等受到破坏的处理

异常断电导致ORACLE控制文件等受到破坏的处理

WBOY
WBOY原创
2016-06-07 17:40:37940浏览

故障现象:客户某台WINDOWS服务器掉电,ORACLE数据库STARTUP提示控制文件CONTROL01.CTL、CONTROL02.CTL被破坏。一、处理控制文件异常故障方法:直接拷贝CONTROL0

 

一、处理控制文件异常故障


二、尝试启动

SQL> startup;

ORACLE 例程已经启动。

Total System Global Area  612368384 bytes

Fixed Size                  1250428 bytes

Variable Size             146803588 bytes

Database Buffers          457179136 bytes

Redo Buffers                7135232 bytes

数据库装载完毕。


SQL> recover database;

完成介质恢复。

SQL> shutdown immediate;

ORA-01109: 数据库未打开

已经卸载数据库。

ORACLE 例程已经关闭。

SQL> startup;

ORACLE 例程已经启动。

 

Total System Global Area  612368384 bytes

Fixed Size                  1250428 bytes

Variable Size             146803588 bytes

Database Buffers          457179136 bytes

Redo Buffers                7135232 bytes

数据库装载完毕。

ORA-00607: 当更改数据块时出现内部错误


SQL> SELECT SEGMENT_NAME FROM DBA_ROLLBACK_SEGS;

SEGMENT_NAME

------------------------------

SYSTEM

_SYSSMU1$

_SYSSMU2$

_SYSSMU3$

_SYSSMU4$

_SYSSMU5$

_SYSSMU6$

_SYSSMU7$

_SYSSMU8$

_SYSSMU9$

_SYSSMU10$

 

SEGMENT_NAME

------------------------------

_SYSSMU11$

_SYSSMU12$

_SYSSMU13$

_SYSSMU14$

_SYSSMU15$

_SYSSMU16$

_SYSSMU17$

_SYSSMU18$


SQL>

SQL>从 SPFILE 创建 PFILE='D:oracleproduct10.2.0oradatazjportBACKFILEORACLEADMINORCLPFILEINITORCL.ORA';

文件已创建。

添加下面的参数:

undo_management='手动'

_corrupted_rollback_segments=

(_SYSSMU1&,_SYSSMU2&,_SYSSMU3&,_SYSSMU4&,_SYSSMU5&,_SYSSMU6&,_SYSSMU7&,_SYSSMU8&,_SYSSMU9&,_SYSSMU10&,_SYSSMU11&,_SYSSMU12&,_SYSSMU13&,_SYSSMU14&,_ SYSSMU15&,_SYSSMU16&,_SYS

SMU17&,_SYSSMU18&)

C:Documents and SettingsAdministrator>sqlplus / as sysdba


版权所有 (c) 1982、2005,Oracle。  版权所有。

已连接到空闲例程。

SQL>启动 PFILE=D:oracleproduct10.2.0oradatazjportBACKFILEORACLEADMINORCLPFILEINITORCL.ORA MOUNT

ORACLE 例程已经启动。

系统全局区域总计 612368384 字节

固定大小                  1250428 字节

可变大小             146803588 字节

数据库缓冲区          457179136 字节

重做缓冲区                7135232 字节

数据库装载完毕。

7、介质恢复

SQL>恢复数据库;

介质完成恢复。

SQL>使用备份控制文件恢复数据库直到取消

D:ORACLEPRODUCT10.2.0FLASH_RECOVERY_AREAZJPORTARCHIVELOG2012_09_20O1_MF_1_145_%U_.ARC


指定日志:{=建议|文件名 |自动 |取消}

取消

介质恢复已取消。

SQL>更改数据库打开重置日志;

数据库已更改。

SQL>

-------------------------------------------------------- ----------

至此数据库恢复,服务器空间,后续执行数据备份并写入SPFILE

-------------------------------------------------------- ----------

1、数据库备份

从 pfile='D:oracleproduct10.2.0oradatazjportBACKFILEORACLEADMINORCLPFILEINITORCL.ORA' 创建 spfile;

-------------------------------------------------------- ----------------------------------

至此数据库完全恢复、数据也备份完成,香港虚拟主机,香港虚拟主机,后续修改不归档方式为归档方式 

-------------------------------------------------------- ----------------------------------

 

--归档路径

SQL>更改系统设置 log_archive_dest_1='LOCATION=D:oracleproduct10.2.0oradatazjportarchivelog';

--归档命名格式

SQL>更改系统设置 log_archive_max_processes = 5;

SQL> alter system set log_archive_format = "archive_%t_%s_%r.arc" scope=spfile;

2、重启数据库

SQL> shutdown immediate

SQL> startup mount;

SQL> alter database archivelog;

SQL> alter database open;

3、确认

SQL> archive log list;

本文出自 “麦地坞” 博客,请务必保留此出处

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn