Oracle 坏块处理。
来源:互联网 发布:数据库培训机构 编辑:程序博客网 时间:2024/04/28 02:24
资料引用:http://www.knowsky.com/388986.html
亲身操作成功!(当然那个坏块的数据会丢失,如果要完整数据,只能用全备恢复,或用归档恢复了)
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#(这两个值可以在报错的ora_01578后面的信息里找到,如:ORA-01578: ORACLE data block corrupted (file # 19, block # 1450394) )
我的显示结果指出是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(这个命令需到后台SQLPLUS去执行,PL/SQL会报错。)
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、 要及时的检查硬件的状态,及时更换驱动器部件。
- Oracle 坏块处理。
- 处理oracle坏块
- oracle坏块处理
- oracle 坏块处理脚本
- Oracle坏块问题处理 Oracle坏块修复 Oracle坏块怎么办
- 磁盘块坏处理ORACLE跳过坏块解决方法
- ORACLE坏块(ORA-01578)处理方法
- ORACLE坏块(ORA-01578)处理方法
- 怎样处理Oracle数据库中的坏块
- 处理Oracle数据库中的坏块
- 如何处理Oracle数据库中的坏块
- 如何处理Oracle中的坏块
- 如何处理Oracle中的坏块
- Oracle ORA-01578坏块处理
- oracle无备份坏块处理
- oracle 坏块的处理方法
- Oracle坏块修复处理实验
- 坏块处理一
- Android播放器框架分析
- WebService的缓存
- 在线碰撞器试用
- 正则表达式语法参考
- 尽快溶入团队,打出自己的身价
- Oracle 坏块处理。
- MyEclipse 9.1 自导jar包构建SSH中jar包的删减
- JS正则表达式语法
- 小结 vsftp、nfs的功用及意义
- 入冬上下班高峰时段市民抱怨乘公交拥挤像春运
- Ant error: Could not find xml-commons-apis Java extension for this JVM解决方法
- Android Fragment学习笔记(一)
- 利用php调用C语言 扩展PHP的功能
- linux下截图工具