网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > 数据库技术 > Oracle > 性能调优 > 详细讲解Oracle物理结构故障的处理方法-性能调优  

详细讲解Oracle物理结构故障的处理方法-性能调优

2008-06-27  作者:bitsCN整理  来源:中国网管联盟  点评 投稿 收藏

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

网管下载dl.bitscn.com

  控制文件损坏:

网管网www.bitscn.com

  控制文件记录了关于oracle的重要配置信息,如数据库名、字符集名字、各个数据文件、日志文件的位置等等信息。控制文件的损坏,会 网管下载dl.bitscn.com

导致数据库异常关闭。一旦缺少控制文件,数据库也无法启动,这是一种比较严重的错误。 中国网管论坛bbs.bitsCN.com

  可以通过查询数据库的日志文件来定位损坏了的控制文件。日志文件位于$ORACLE_BASE/admin/bdump/alert_ORCL.ora.

网管朋友网www_bitscn_net

  损坏单个控制文件: 网管联盟bitsCN_com

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

网管u家www.bitscn.net

  svrmgrl>shutdown immediate; 网管u家www.bitscn.net

  2. 查看初始化文件$ORACLE_BASE/admin/pfile/initORCL.ora,确定所有控制文件的路径。 网管联盟bitsCN_com

  3. 用操作系统命令将其它正确的控制文件覆盖错误的控制文件。

网管有家www.bitscn.net

  4. 用下面的命令重新启动数据库 网管u家u.bitsCN.com

  svrmgrl>startup;

网管网www_bitscn_com

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

网管联盟bitsCN@com

  损坏所有的控制文件: 网管u家u.bitsCN.com

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

中国网管论坛bbs.bitsCN.com

  svrmgrl>shutdown immediate;

网管有家www.bitscn.net

  2. 从相应的备份结果集中恢复最近的控制文件。对于没有采用带库备份的点可以直接从磁带上将最近的控制文件备份恢复到相应目录;对 网管u家u.bitscn@com

于采用带库备份的点用相应的rman脚本来恢复最近的控制文件。

网管有家bitscn.net

  3. 用下面的命令来创建产生数据库控制文件的脚本: 网管联盟bitsCN@com

  svrmgrl>startup mount; 网管u家u.bitscn@com

  svrmgrl>alter database backup controlfile to trace noresetlogs;

网管有家bitscn.net

  4. 修改第三步产生的trace文件,将其中关于创建控制文件的一部分语句拷贝出来并做些修改,使得它能够体现最新的数据库结构。假设 网管有家www.bitscn.net

产生的sql文件名字为createcontrol.sql.

网管u家www.bitscn.net

  注意: 中国网管论坛bbs.bitsCN.com

  Trace文件的具体路径可以在执行完第3)步操作后查看$ORACLE_BASE/admin/bdump/alert_ORCL.ora文件来确定。 网管联盟bitsCN_com

  5. 用下面命令重新创建控制文件: 网管论坛bbs_bitsCN_com

  svrmgrl>shutdown abort; 网管联盟bitsCN@com

  svrmgrl>startup nomount;

网管有家bitscn.net

  svrmgrl>@createcontrol.sql;

中国网管论坛bbs.bitsCN.com

  6. 用适当的方法进行数据库全备份。 网管u家www.bitscn.net

  重做日志文件损坏:

网管朋友网www_bitscn_net

  数据库的所有增、删、改都会记录入重做日志。如果当前激活的重做日志文件损坏,会导致数据库异常关闭。非激活的重做日志最终也会

网管联盟bitsCN@com

因为日志切换变为激活的重做日志,所以损坏的非激活的重做日志最终也会导致数据库的异常终止。在ipas/mSwitch中每组重做日志只有一个

网管u家www.bitscn.net

成员,所以在下面的分析中只考虑重做日志组损坏的情况,而不考虑单个重做日志成员损坏的情况。 网管网www.bitscn.com

  确定损坏的重做日志的位置及其状态: 中国网管联盟bitsCN.com

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

网管u家www.bitscn.net

  select * from v$logfile; 中国网管论坛bbs.bitsCN.com

  svrmgrl>select * from v$log; 网管朋友网www_bitscn_net

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

网管u家www.bitscn.net

  svrmlgr>startup mount;

中国网管论坛bbs.bitsCN.com

  svrmgrl>select * from v$logfile;

中国网管联盟bitsCN.com

  svrmgrl>select * from v$log;

网管bitscn_com

  其中,logfile的状态为INVALID表示这组日志文件出现已经损坏;log状态为Inactive:表示重做日志文件处于非激活状态;Active: 表示 网管网www_bitscn_com

重做日志文件处于激活状态;Current:表示是重做日志为当前正在使用的日志文件。 网管u家u.bitscn@com

  损坏的日志文件处于非激活状态: 网管下载dl.bitscn.com

  1. 删除相应的日志组: 中国网管论坛bbs.bitsCN.com

  svrmgrl>alter database drop logfile group group_number; 网管有家bitscn.net

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

中国网管论坛bbs.bitsCN.com

  svrmgrl>alter database add log file group group_number (’log_file_descritpion’,…) size log_file_size; 中国网管论坛bbs.bitsCN.com

  损坏的日志文件处于激活状态且为非当前日志: 网管联盟bitsCN_com

  1. 清除相应的日志组:

网管bitscn_com

  svrmgrl>alter database clear unarchived logfile group group_number; 网管u家u.bitscn@com

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

网管下载dl.bitscn.com

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

中国网管联盟bitsCN.com

  svrmgrl>alter database clear unarchived logfile group group_number;

网管u家www.bitscn.net

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

网管网www.bitscn.com

  打开数据库并且用适当的方法进行数据库全备份: 网管联盟bitsCN@com

  svrmgrl>alter database open; 网管联盟bitsCN_com

  部分数据文件损坏: 网管联盟bitsCN_com

  若损坏的数据文件属于非system表空间,则数据库仍然可以处于打开状态可以进行操作,只是损坏的数据文件不能访问。这时在数据库打

网管联盟bitsCN@com

开状态下可以单独对损坏的数据文件进行恢复。若是system表空间的数据文件损坏则数据库系统会异常终止。这时数据库只能以Mount方式打开 中国网管联盟bitsCN.com

,然后再对数据文件进行恢复。可以通过查看数据库日志文件来判断当前损坏的数据文件到底是否属于system表空间。

网管网www.bitscn.com

  非system表空间的数据文件损坏

中国网管论坛bbs.bitsCN.com

  1. 确定损坏的文件名字:

网管u家u.bitsCN.com

  svrmgrl>select name from v$datafile where status=’INVALID’; 网管u家u.bitscn@com

  2. 将损坏的数据文件处于offline状态: 网管网www.bitscn.com

  svrmgrl>alter database datafile ‘datafile_name’ offline;

中国网管论坛bbs.bitsCN.com

  3. 从相应的备份结果集中恢复关于这个数据文件的最近的备份。对于没有采用带库备份的点可以直接从磁带上恢复;对于用带库备份的点 网管联盟bitsCN@com

用相应的rman脚本来恢复。 网管朋友网www_bitscn_net

  4. 恢复数据文件: 网管联盟bitsCN_com

  svrmgrl>alter database recover datafile ‘file_name’;

网管网www.bitscn.com

  5. 使数据库文件online: 网管u家bitscn.net

  svrmgrl>alter database datafile ‘datafile_name’ online; 网管网www_bitscn_com

网管有家bitscn.net

TAGs   处理   方法   性能   故障   结构   讲解   物理   详细   数据库   文件      
 上一篇:Oracle只希望红帽存在Linux不应分裂-性能调优   下一篇:SQL 2005 XML最佳实施策略用法-性能调优
详细讲解Oracle物理结构故障的处理方法-性能调优 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: