网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.ORACLE数据库常见问题诊断方法.
.ORACLE 服務器的配置及優化.
.Oracle专家调优秘密(二).
.一次分析的全过程.
.教你如何截获Oracle数据库连接密.
.oracle中的to_date参数含义.
.Linux简明系统维护手册(3).
.Linux Shadow-Password-HOWTO.
.如何移动表达到减小数据文件大小.
.Oracle的客户端工具--sql*plus.
.ORACLE常用傻瓜问题1000问全集(.
.ORACLE 截断字符串.
.Oracle Online Redo LogFile 全面.
.使 Oracle 能同时访问多个SQL Se.
.Oracle数据库备份与恢复的三种方.
.教你如何使用 J2ME 实现移动支付.
.Oracle数据库数据锁定机制全面解.
.关于fast_start_io_target的一点.
.ORACLE OLAP函数语法的总结.
.Oracle性能优化系列讲座之技巧篇.

ORACLE坏块(ORA-01578)处理方法

发表日期:2008-2-9



  
Oracle的坏块即ORA-01578错,同时还可能伴随ORA-01110错,这种错误对于初学者或是那些没有实践经验的dba来说无疑是很棘手的。我当初就深受其害,写下这篇文章则是希望对大家有所帮助。

一、出问题时的情景

1、  我的一个计费的入库的进程停掉,报的便是ORA-01578错,对应用相关的表tg_bill03做SQL>select from tg_cdr03 where rownum<10;这样是可以的,但做SQL>select count(*) from tg_bill03;时则报ORA-01578错。

2、  检查alter<sid>.log中看到一几条报错信息:

  Errors in file /oracle816/app/admin/billing/udump/ora_7281_billing.trc:

  ORA-01578: ORACLE data block corrupted (file # 126, block # 88490)

  ORA-01110: data file 126: '/dev/vgjf7/rdata471'

 

二、事后分析产生这种问题的原因

1、  十之八九这个Oracle的数据库server打开了异步I/O(async io)或增加了写进程。

2、  硬件的I/O出现了错误。

3、  操作系统的I/O或缓存出现我问题,比如操作系统对于异步I/O的补丁没有打。

4、  手动的修改了数据文件中的数据,我模拟这个错误用的便是这种方式。

 

三、解决方法

这种问题的解决方法是很多的,假如你用的是归档方式,则可以基于时间点恢复来解决。不过这里介绍一种比较方便的解决方式,因为我的库没有开归档。Metaline关于ORA-01578的文字也很多,不过我看过后总觉得都不那么实用,不能解决实际的问题。

1、  解决这种问题的第一步是首先你要确定是什么段、哪个段坏了,是索引还是表?

A、 打开alter<sid>.log,找到ORA-01578的报错信息,并记录下file#及block的值,我这里是126和88490。

B、 执行以下语句看哪个段坏了

  SQL>Select * from dba_extents

2  where  file_id=<F>

3  and <B> between block_id and block_id+blocks-1;

          这里的F指的是file#,B指的是block#

          我的显示结果指出是tg_bill03出现了坏块。

  

2、假如确定下来坏的是索引段,这时你就可以轻舒一口气了,只要把这个索相删除然后重建一下就可以了,假如出现坏的是表段,则应往下走了。

 

3、  记录下这个表的建表语句

为我方便,建议使用PL/SQL Developer来完成,假如你没有可以在http://www.allroundautomations.com/plsqldev.Html去下载一个,操作步骤是这样的。

A、 以表的owner用pl/sql developer连入oracle

B、 在左面的树状栏中找到这个表tg_bill03,右击该表->view->View SQL,记录下sql,以备以下步骤中重建索引。

4、  实际处理了,以我的那个表为例

A、 以tg_bill03的owner连入oracle

B、 使用诊断事件10231

    SQL> ALTER SYSTEM SET EVENTS ‘10231 trace name context forever,level 10’;

C、创建一个临时表tg_bill_tmp的表中除坏块的数据都检索出来

SQL>CREATE TABLE tg_bill03_tmp as select * from tg_bill03;

C、 更名原表,并把tg_bill03_tmp为tg_bill03

SQL>alter table tg_bill03 rename to tg_bill03_bak;

SQL>alter table tg_bill03_tmp to tg_bill03;

D、在tg_bill03上重新创建索引、约束、授权、trigger等对象

E、 利用表之间的业务关系,把坏块中的数据补足。


 

四、如何尽量减少问题及问题的损失呢

 分析了产生问题的原因,我认为可以采取以下几个措施

1、  在为提高性能为操作系统打开异步I/O时,一定要与oracle及操作系统技术支持联系把操作系统与异步I/O相关的补丁要打全。

2、  制定一个良好的备份恢复策略,最好有表的eXP备份

3、  要及时的检查硬件的状态,及时更换驱动器部件。

 

结篇:其实坏块涉及的内容很多的,假如坏块发生的回滚段表空间、数据字典(system表空间)或联机日志,这些处理都是特难的,需要与oracle的supporter联系。不过这些方面的坏的机率很少很少的,在以后的文章中我也会做介绍。
上一篇:ORACLE DATE和TIMESTAMP数据类型的比较(一) 人气:1256
下一篇:ORACLE常用第三方软件介绍 人气:695
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐