我的第一次坏块故障恢复经历

前几天由于单位断电了,导致一台BK*应用的开发数据库环境无法open打开,本以为借助于advise/repair failure就可以实现恢复,中间还是费了不少周折。

这算是自己第一次处理稍微比较复杂的恢复问题,以前碰见的问题都是比较常规简单的,对于备份恢复来说,一直想找一个时间更系统的学习一下,这个问题处理的过程当中才发现这些基础理论的重要性,因此一些处理步骤上还是比较混乱的,思路并不是很清晰,胡子眉毛一把装,尝试了所有会用或能用的方法,虽然最后拉起了库,但按照惜分飞大师的说法,还是有一些幸运的成分,不得不承认,差距还是很大,因此下面叙述中要有不到位的,还请各位指正。

环境信息:
版本:12.1.0.2.0
用途:开发环境
其他信息:未开启归档模式
现象:上班后开发人员发现start数据库错误,根据网上的信息,做了重建控制文件等操作,但依旧无法启动,系统此时已经有些混乱了,可能都记不太清楚还做了什么。

1.使用LIST/ADVISE/REPAIR FAILURE
尝试使用LIST FAILURE,发现有几个HIGH、CRITICAL的错误,由于未截图,所以只能描述,记得其中一个错误是某个数据文件出现了坏块,另一个错误是控制文件不是最新状态,好像还有个错误是系统表空间SYSTEM出现坏块(印象已经不深了)。
使用ADVISE FAILURE,指出了一些修复的方法和脚本。
然后执行了REPAIR FAILURE,执行了自动修复,发现一直刷屏,等了许久未结束,强制结束后,再次执行LIST FAILURE,发现仍旧存在数据文件坏块的错误。

2.查询有坏块的数据文件信息
使用dbv检测这一个有问题的数据文件,

从V$DATABASE_BLOCK_CORRUPTION视图查看坏块信息,

说明是10号文件的1678871和1678883块,各自有一个坏块。

其中,CORRUPTION_TYPE都是FRACTURED,表示块头看起来是正常,但是块中存在不一致的版本。

使用如下SQL可以查看这些坏块中具体存在什么信息,

说明坏块中存在的一张表使用的索引。

3.尝试修复坏块
尝试重建索引看看,

提示数据文件块损坏,显然这种方式行不通了。
说到修复坏块,江湖上还是有一些神器的,查了下,
(1) ODU:ORACLE DATABASE UNLOADER,老熊和dbsnake现在负责维护。
(2) DUL:DATA UNLOADER,Oracle内部的一个非商业化产品。
(3) AUL:也称MyDUL,d.b.c.a(楼方鑫)大神负责维护。
(4) 刘大的PRM-DUL。
(5) bbed,可以做一些数据块修改的工作。
我之前没有用过任何一款,现学起来还是需要些时间。以上软件大部分有免费版,但对数据文件大小有限制,只能做很小的数据恢复,要想全部恢复,就要买license,虽然我和dbsnake是同事,但为了这么个开发库,而且是这么一个我认为在大神看来其实可能很简单的问题,还是别来麻烦别人了,自己选择继续扛下来,也算让自己锻炼一把。

4.尝试屏蔽坏块数据文件
既然是索引,不是数据,尝试下是不是可以屏蔽这个存在坏块的数据文件。
重建控制文件,可以参考eygle的文章《如何获得创建控制文件的脚本并重建控制文件》(http://www.eygle.com/faq/How.To.Backup.and.Recreate.Controlfile.htm)

生成的控制文件模版中有RESETLOGS/NORESETLOGS两种模式,采用noresetlogs脚本的控制文件,执行,

提示open的时候出现了ORA-00600的错误。

再查看alert日志,







出现了一系列ORA-00600的错误,最后由PMON进程结束了数据库实例的操作。我们知道ORA-600除了是我们李老师的网名:)之外,是Oracle中比较著名的一个错误号。可以参考戴老师这篇文章,对600错误有一个比较详细的解释(http://blog.csdn.net/tianlesoftware/article/details/6645809/)。

从报错看,ORA-00600跟着的参数,第一个是4194、4137,从定义看,都是和交易相关,

Primarily the transaction layer is involved with maintaining
structures associated with the management of transactions. As with the cache layer , problems encountered in this layer may indicate some kind of issue at a physical level. Thus it is important to try and repeat the same steps to see if the problem recurs.

彭小波大师推荐了一篇MOS文章(Step by step to resolve ORA-600 4194 4193 4197 on database crash (文档 ID 1428786.1)),惜分飞博客文章中有译文(《ORA-600 4194/ORA-600 4193/ORA-600 4137故障解决》http://www.xifenfei.com/2016/08/ora-600-4194-ora-600-4193-ora-600-4137.html)。

描述的就是alert中出现ORA-00600 4xxx错误的原因,

This error indicates that a mismatch has been detected between redo records and rollback (undo) records.

同时给出了解决方案,

Create pfile from spfile to edit
create pfile from spfile;

  1. Shutdown the instance
  2. set the following parameters in the pfile
    undo_management = manual
    event = ‘10513 trace name context forever, level 2’
  3. startup restrict pfile=initsid.ora
  4. select tablespace_name, status, segment_name from dba_rollback_segs where status != ‘OFFLINE’;
    This is critical - we are looking for all undo segments to be offline - System will always be online.
    If any are ‘PARTLY AVAILABLE’ or ‘NEEDS RECOVERY’ - Please open an issue with Oracle Support or update the current SR. There are many options from this moment and Oracle Support Analyst can offer different solutions for the bad undo segments.
    If all offline then continue to the next step
  5. Create new undo tablespace - example
    create undo tablespace datafile size 2000M;
  6. Drop old undo tablespace
    drop tablespace including contents and datafiles;
  7. shutdown immediate;
  8. startup nomount; – Using your Original spfile
  9. modify the spfile with the new undo tablespace name
    Alter system set undo_tablespace = ‘’ scope=spfile;
  10. shutdown immediate;
  11. startup; – Using spfile

之所以创建新回滚表空间的原因,就是因为他的回滚段序号要高于目前正使用的段,这样在一个交易需要参考已经不存在的回滚段做块清除操作的时候,才会继续完成这项操作。

The reason we create a new undo tablespace first is to use new undo segment numbers that are higher then the current segments being used. This way when a transaction goes to do block clean-out the reference to that undo segment does not exist and continues with the block clean-out.

尝试下操作。
(1) 根据spfile创建pfile,

create pfile from spfile;

(2) 停止实例,编辑文件,增加:

*.undo_management=manual
*.event='10513 trace name context forever, level 2'

使用文件pfile以restrict启动,

SQL> startup restrict pfile=/u01/app/oracle/product/12.1.0/dbhome_1/dbs/initXXXXX.ora

(3) 查看dba_rollback_segs视图,

发现并不是像上面文章说的OFFLINE状态,是PARTLY AVAILABLE,换句话说需要SR?先创建了新的回滚表空间UBDOTBS2再说。

(4) 删除旧回滚表空间错误,

(5) 参考http://www.linuxidc.com/Linux/2014-06/103780.htm,屏蔽这些SYSSMU表空间,pfile文件增加,

(6) 再次重启删除,

SQL> drop tablespace undotbs1 including contents and datafiles;

正常,

(7) 再次重启,切换表空间,

(8) 数据库可以打开了,查询一些应用表,可是报错了,

开始想出的方法是使用

select dbms_metadata.get_ddl('TABLE','XXX','XXX') from dual;
select dbms_metadata.get_ddl('INDEX','XXX','XXX') from dual;

得出原始建表和索引的语句,但数据无法恢复。

(9) 参考http://blog.csdn.net/sdulsj/article/details/52993052,设置10231事件后使用CTAS方式重建表,

再使用表所属用户执行rename创建原表,

记得关闭事件,

此时,表数据可以恢复使用了,

总结:
1.备份恢复的基础,还是需要理解数据库运转的工作原理,出现任何报错,都是有原因,提示的信息非常重要,要能透过现象看出本质。这不是一朝一夕就能掌握的技能,但需要一朝一夕的积累,这块还需要自己多努力学习和实践。
2.还是需要有备份,如果开启了归档,或者有一些冷备,恢复起来就会方便一些。即使这是一套开发库。
3.整个过程还要感谢白鳝、惜分飞、彭小波以及道长的支持。

欢迎关注我的个人微信公众号:bisal的个人杂货铺

时间: 2024-10-27 22:18:04

我的第一次坏块故障恢复经历的相关文章

Oracle 12C的第一次异常恢复—文件头坏块

接到第一个使用Oracle 12C作为生产库的恢复救援.有两个业务数据文件报文件头损坏,其他数据文件全部是9月份的一次备份,在当前的条件下,希望我们能够帮他们恢复出来业务文件中的数据数据库版本信息  代码如下 复制代码 SQL> select * from v$version; BANNER                                                                               CON_ID-------------------

一道面试题:遇到大规模Oracle坏块该怎么处理?

最近一两个月,一直有场景化运维.场景化大数据分析的声音围绕在耳畔,以Gdevops全球敏捷运维峰会杭州站上新炬网络执行副总裁程永新的"一切没有场景驱动的运维平台建设都是假大空!"最为振聋发聩.我们一直在谈技术,谈原理,谈内核,总以为"懂了"这些的人,就势必能广阔天地大有所为.   技术固然重要,但偏离了业务/应用场景的技术,无法呈现业务价值的技术就非常不重要.   技术也应该是场景驱动的,对于运维技术人员来说,离开场景学习的所谓高深技术,只是浪费时间.所以新同事进入

轻量级 NAND 坏块管理方法分析及改进

NAND 及其坏块 NAND Flash 是一种高密度低成本的存储体,它在各种各样的嵌入式系统中获得了广泛的应用, USB 存储设备.SD 卡.手机.相机和固态硬盘等各种设备中使用的都是 NAND 芯片.其内部结构是按照块/页进行组织的,一个 NAND 芯片包含若干个块,而块内部又是由若干个页构成的.NAND 芯片出厂时就可能包含若干个坏块,在使用过程中也可能会产生新的坏块,当一个块被标记为坏块后,不应再对其写入数据,以免出现数据丢失.由于 NAND 擦写次数是有限的,而且会在使用过程中产生新的

如果处理Oracle数据库中的坏块问题

oracle|数据|数据库|问题 Oracle的数据块有固定的格式和结构,分三层: Cache layer.Transaction layer和Data layer.对数据块进行读写操作时,做一致性检查:–Block type–DBA–Scn –Header and tail 发现不一致,标记为坏块. 坏块有两种: 物理坏块和逻辑坏块. 坏块产生的影响:数据字典表.回滚段表.临时段和用户数据表和索引.应用报错:–Ora-1578 –Ora-600 and trace file in bdump

用ORACLE8i修复数据库坏块的三种方法

oracle|数据|数据库 在进行SUN CLUSTER双机切换.意外断电或其它情况下,有时会发生共享盘MOUNT不上的情况,需要使用FSCK对共享盘进行修复.修复完成后,在数据库启动过程中,却又出现"数据块损坏,无法启动数据库"的现象,此时,可以根据不同的数据块损坏类型,检测并修复错误.在此介绍三种使用Oracle8i修复损坏数据块的方法. 一.数据块损坏,错误代码为ORA-01578 ORA-1115 I/O ERROR READING BLOCK 通常后跟ORA-737X错误与操

如何处理Oracle数据库中的坏块问题

oracle|数据|数据库|问题   本文主要介绍如何去处理在Oracle数据库中出现坏块的问题,对于坏块产生在不同的对象上,处理的方法会有所不同,本文将大致对这些方法做一些介绍.因为数据库运行时间长了,由于硬件设备的老化,出现坏块的几率会越来越大,因此,做为一个DBA,怎么去解决数据库出现的坏块问题就成了一个重要的议题了.   一:什么是数据库的坏块   首先我们来大概看一下数据库块的格式和结构 数据库的数据块有固定的格式和结构,分三层:cache layer,transaction laye

oracle8i回滚段表空间出现坏块的解决方法

oracle|解决 今天早上刚到公司便接到网通客户的投诉电话,说网管数据库出问题了,数据库有坏块,回滚段里的部分数据不能读取,需要帮忙解决. 我查看了一下swappALRT.log文件,发现有以下错误: Tue Sep 21 10:34:08 2004Errors in file E:\oracle\admin wapp\bdump wappSMON.TRC:ORA-01578: ORACLE data block corrupted (file # 2, block # 24497)ORA-0

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

oracle ORACLE的坏块即ORA-01578错,同时还可能伴随ORA-01110错,这种错误对于初学者或是那些没有实践经验的dba来说无疑是很棘手的.我当初就深受其害,写下这篇文章则是希望对大家有所帮助. 一.出问题时的情景 1.  我的一个计费的入库的进程停掉,报的便是ORA-01578错,对应用相关的表tg_bill03做SQL>select from tg_cdr03 where rownum<10;这样是可以的,但做SQL>select count(*) from tg_

ORA-01578及ORA-01110坏块如何解决

一个案例,查看跟踪文件发现如下错误信息 d:\oracle\product\10.2.0\admin\dbserver\udump\orcl_ora_5888.trc Corrupt block relative dba: 0x09848269 (file 38, block 295529) Bad header found during buffer read Data in bad block: type: 1 format: 5 rdba: 0x30322d2d last change s