Oracle数据库系统紧急故障处理方法

2008-04-02 10:41:46来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

Oracle物理结构故障是指构成数据库的各个物理文档损坏而导致的各种数据库故障。这些故障可能是由于硬件故障造成的,也可能是人为误操作而引起。所以我们首先要判断问题的起因,假如是硬件故障则首先要解决硬件问题。在无硬件问题的前提下我们才能按照下面的处理方发来进一步处理。

  控制文档损坏:

  控制文档记录了关于oracle的重要配置信息,如数据库名、字符集名字、各个数据文档、日志文档的位置等等信息。控制文档的损坏,会导致数据库异常关闭。一旦缺少控制文档,数据库也无法启动,这是一种比较严重的错误。

  损坏单个控制文档:

  1. 确保数据库已关闭,假如没有用下面的命令来关闭数据库:

  svrmgrl>shutdown immediate;

  2. 查看初始化文档$ORACLE_BASE/admin/pfile/initORCL.ora,确定任何控制文档的路径。
 
  3. 用操作系统命令将其他正确的控制文档覆盖错误的控制文档。

  4. 用下面的命令重新启动数据库:

  svrmgrl>startup;

  5. 用适当的方法进行数据库全备份。

  损坏任何的控制文档:

  1. 确保数据库已关闭,假如没有用下面的命令来关闭数据库:

  svrmgrl>shutdown immediate;

  2. 从相应的备份结果集中恢复最近的控制文档。对于没有采用带库备份的点能够直接从磁带上将最近的控制文档备份恢复到相应目录;对于采用带库备份的点用相应的rman脚本来恢复最近的控制文档。

  3. 用下面的命令来创建产生数据库控制文档的脚本:

svrmgrl>startup mount;

svrmgrl>alter database backup controlfile to trace noresetlogs;

  4. 修改第三步产生的trace文档,将其中关于创建控制文档的一部分语句拷贝出来并做些修改,使得他能够体现最新的数据库结构。假设产生的sql文档名字为createcontrol.sql.

  注意:

  Trace文档的具体路径能够在执行完第3)步操作后查看$ORACLE_BASE/admin/bdump/alert_ORCL.ora文档来确定。

  5. 用下面命令重新创建控制文档:

  svrmgrl>shutdown abort;

  svrmgrl>startup nomount;

  svrmgrl>@createcontrol.sql;

  6. 用适当的方法进行数据库全备份。

  重做日志文档损坏:

  数据库的任何增、删、改都会记录入重做日志。假如当前激活的重做日志文档损坏,会导致数据库异常关闭。非激活的重做日志最终也会因为日志转换变为激活的重做日志,所以损坏的非激活的重做日志最终也会导致数据库的异常终止。在ipas/mSwitch中每组重做日志只有一个成员,所以在下面的分析中只考虑重做日志组损坏的情况,而不考虑单个重做日志成员损坏的情况。

  确定损坏的重做日志的位置及其状态:

  1. 假如数据库处于可用状态:

  select * from v$logfile;

  svrmgrl>select * from v$log;

  2. 假如数据库处于已异常终止:

  svrmlgr>startup mount;
  svrmgrl>select * from v$logfile;
  svrmgrl>select * from v$log;

  其中,logfile的状态为INVALID表示这组日志文档出现已损坏;log状态为Inactive:表示重做日志文档处于非激活状态;Active: 表示重做日志文档处于激活状态;Current:表示是重做日志为当前正在使用的日志文档。

  损坏的日志文档处于非激活状态:

  1. 删除相应的日志组:

  svrmgrl>alter database drop logfile group group_number;

  2. 重新创建相应的日志组:

  svrmgrl>alter database add log file group group_number (’log_file_descritpion’,…) size log_file_size;

  损坏的日志文档处于激活状态且为非当前日志:

  1. 清除相应的日志组:

  svrmgrl>alter database clear unarchived logfile group group_number;

  损坏的日志文档为当前活动日志文档:

  用命令清除相应的日志组:

  svrmgrl>alter database clear unarchived logfile group group_number;

  假如清除失败,则只能做基于时间点的不完全恢复。

  打开数据库并且用适当的方法进行数据库全备份:

  svrmgrl>alter database open;

  部分数据文档损坏:

  若损坏的数据文档属于非system表空间,则数据库仍然能够处于打开状态能够进行操作,只是损坏的数据文档不能访问。这时在数据库打开状态下能够单独对损坏的数据文档进行恢复。若是system表空间的数据文档损坏则数据库系统会异常终止。这时数据库只能以Mount方式打开,然后再对数据文档进行恢复。能够通过查看数据库日志文档来判断当前损坏的数据文档到底是否属于system表空间。


标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: 使用SQL

下一篇: 问题“未于信任SQL