标签云
asm恢复 bbed bootstrap$ dul In Memory kcbzib_kcrsds_1 kccpb_sanity_check_2 MySQL恢复 ORA-00312 ORA-00607 ORA-00704 ORA-00742 ORA-01110 ORA-01555 ORA-01578 ORA-01595 ORA-08103 ORA-600 2131 ORA-600 2662 ORA-600 3020 ORA-600 4000 ORA-600 4137 ORA-600 4193 ORA-600 4194 ORA-600 16703 ORA-600 kcbzib_kcrsds_1 ORA-600 KCLCHKBLK_4 ORA-15042 ORA-15196 ORACLE 12C oracle dul ORACLE PATCH Oracle Recovery Tools oracle加密恢复 oracle勒索 oracle勒索恢复 oracle异常恢复 Oracle 恢复 ORACLE恢复 ORACLE数据库恢复 oracle 比特币 OSD-04016 YOUR FILES ARE ENCRYPTED 勒索恢复 比特币加密文章分类
- Others (2)
- 中间件 (2)
- WebLogic (2)
- 操作系统 (103)
- 数据库 (1,767)
- DB2 (22)
- MySQL (77)
- Oracle (1,608)
- Data Guard (52)
- EXADATA (8)
- GoldenGate (24)
- ORA-xxxxx (166)
- ORACLE 12C (72)
- ORACLE 18C (6)
- ORACLE 19C (15)
- ORACLE 21C (3)
- Oracle 23ai (8)
- Oracle ASM (69)
- Oracle Bug (8)
- Oracle RAC (54)
- Oracle 安全 (6)
- Oracle 开发 (28)
- Oracle 监听 (29)
- Oracle备份恢复 (590)
- Oracle安装升级 (97)
- Oracle性能优化 (62)
- 专题索引 (5)
- 勒索恢复 (86)
- PostgreSQL (30)
- pdu工具 (6)
- PostgreSQL恢复 (9)
- SQL Server (32)
- SQL Server恢复 (13)
- TimesTen (7)
- 达梦数据库 (3)
- 达梦恢复 (1)
- 生活娱乐 (2)
- 至理名言 (11)
- 虚拟化 (2)
- VMware (2)
- 软件开发 (39)
- Asp.Net (9)
- JavaScript (12)
- PHP (2)
- 小工具 (22)
-
最近发表
- ORA-00756 ORA-10567故障数据0丢失恢复
- 数据库文件变成32k故障恢复
- tcp连接过多导致监听TNS-12532 TNS-12560 TNS-00502错误
- 文件系统格式化MySQL数据库恢复
- .sstop勒索加密数据库恢复
- 解决一次硬件恢复之后数据文件0kb的故障恢复case
- Error in invoking target ‘libasmclntsh19.ohso libasmperl19.ohso client_sharedlib’问题处理
- ORA-01171: datafile N going offline due to error advancing checkpoint
- linux环境oracle数据库被文件系统勒索加密为.babyk扩展名溯源
- ORA-600 ksvworkmsgalloc: bad reaper
- ORA-600 krccfl_chunk故障处理
- Oracle Recovery Tools恢复案例总结—202505
- ORA-600 kddummy_blkchk 数据库循环重启
- 记录一次asm disk加入到vg通过恢复直接open库的案例
- CHECKDB 发现了 N 个分配错误和 M 个一致性错误
- 达梦数据库dm.ctl文件异常恢复
- Oracle Recovery Tools修复ORA-00742、ORA-600 ktbair2: illegal inheritance故障
- 可能是 tempdb 空间用尽或某个系统表不一致故障处理
- 11.2.0.4库中遇到ORA-600 kcratr_nab_less_than_odr报错
- [MY-013183] [InnoDB] Assertion failure故障处理
分类目录归档:Oracle备份恢复
ASM删除表空间恢复
前几天刚刚恢复了一个文件系统层面drop 表空间的case(分享运气超级好的一次drop tablespace 数据恢复),又一客户删除表空间(认为是不要的表空间),结果发现业务上丢失了很多表数据,通过分析和回顾以往事件,确认由于在以前数据迁移过来的过程中,数据写入了和原库一致的表空间,而没有恢复到本该恢复的新表空间中,这次删除该空间导致很多表数据丢失.而且该客户是asm环境,drop tablespace带上了including contents and datafiles语句,导致该表空间对应的数据文件也丢失.对于这类数据的恢复,一般情况下先通过asm层面恢复出来被删除的数据文件,然后再对被删除的数据文件按照丢失system的方式恢复里面的表数据(这个客户有历史备份便于整合)
在恢复被删除的文件之前,需要先确认对应的被删除的表空间信息和对应的文件信息,通过对底层字典分析file$,ts$,结合alert日志,可以确认被删除文件的文件号,文件名称等信息
由于文件已经从asm磁盘组中删除,无法直接恢复,通过对asm磁盘组进行扫描找出对应的block信息,参考:asm磁盘组操作不当导致数据文件丢失恢复类似处理方法,分析文件是否异常
初步判断文件恢复效果应该不错,恢复出来数据文件,然后进行dbv检查
后续的操作比较简单,使用oracle dul恢复出来按照类似方法:dul恢复drop表测试 数据即可,业务进行核对即可.如果你遭遇到此类情况,而且无有效备份,尽可能保护现场(不要对asm/文件系统系统进行写入操作),然后联系我们进行处理,最大限度恢复数据
分享运气超级好的一次drop tablespace 数据恢复
分享一次运气超级好的恢复,本身是一个测试库,应用厂商今天准备把应用正式上线,操作流程是:先删除用户,然后删除表空间,在创建表空间导入数据正式上线,不知何种原因最终客户在测试业务中做了一些正式数据,结果是无情的被删除了,通过alert日志找到应用厂商的一些操作记录
2021年8月份创建了业务表空间
Wed Aug 18 09:49:03 2021 create tablespace xifenfei datafile 'D:\app\Administrator\oradata\xifenfei\xifenfei.dbf' size 10g Wed Aug 18 09:52:28 2021 Completed: create tablespace xifenfei datafile 'D:\app\Administrator\oradata\xifenfei\xifenfei.dbf' size 10g
今天删除表空间
Tue Apr 12 11:15:02 2022 drop tablespace xifenfei including contents and datafiles WARNING: Cannot delete file D:\APP\ADMINISTRATOR\ORADATA\xifenfei\xifenfei.DBF Errors in file d:\app\administrator\diag\rdbms\xifenfei\xifenfei\trace\xifenfei_ora_4296.trc: ORA-01265: 鏃犳硶鍒犻櫎 DATA D:\APP\ADMINISTRATOR\ORADATA\xifenfei\xifenfei.DBF ORA-27056: 鏃犳硶鍒犻櫎鏂囦欢 OSD-04024: 无法删除文件。 O/S-Error: (OS 32) 另一个程序正在使用此文件,进程无法访问。 Completed: drop tablespace xifenfei including contents and datafiles
然后客户创建新表空间提示ORA-01119,然后人工删除掉该数据文件
Tue Apr 12 11:49:02 2022 create tablespace xifenfei datafile'D:\oracle\oradata\xifenfei\xifenfei.dbf'size 20480m ORA-1119 signalled during: create tablespace xifenfei datafile'D:\oracle\oradata\xifenfei\xifenfei.dbf'size 20480m... Tue Apr 12 11:49:16 2022 create tablespace xifenfei datafile'D:\oracle\oradata\xifenfei\xifenfei.dbf'size 20480m ORA-1119 signalled during: create tablespace xifenfei datafile'D:\oracle\oradata\xifenfei\xifenfei.dbf'size 20480m...
创建新表空间成功,并增加数据文件
Tue Apr 12 12:08:43 2022 create tablespace xifenfei datafile'D:\app\Administrator\oradata\xifenfei\xifenfei.dbf'size 5120m Tue Apr 12 12:10:25 2022 Completed: create tablespace xifenfei datafile'D:\app\Administrator\oradata\xifenfei\xifenfei.dbf'size 5120m Tue Apr 12 12:11:19 2022 alter tablespace xifenfei add datafile'D:\app\Administrator\oradata\xifenfei\xifenfei1.dbf'size 5120m Tue Apr 12 12:13:02 2022 Completed: alter tablespace xifenfei add datafile'D:\app\Administrator\oradata\xifenfei\xifenfei1.dbf'size 5120m alter tablespace xifenfei add datafile'D:\app\Administrator\oradata\xifenfei\xifenfei2.dbf'size 5120m Tue Apr 12 12:14:52 2022 Completed: alter tablespace xifenfei add datafile'D:\app\Administrator\oradata\xifenfei\xifenfei2.dbf'size 5120m
基本情况就是客户删除了一个10G的业务数据文件,然后创建了3个5G的业务数据文件,现在要恢复被以前的两个表的核心数据,需要做的就是把以前的10G的数据文件找出来,但是由于删除10G文件之后又写入了15G的数据文件(而且这里面有文件的file#和删除的文件一致),理论上无法直接做block层面扫描恢复,对于此类情况,尝试文件系统层面直接反删除恢复,不过没有任何记录,文件目录被覆盖,这条路走不通.通过block扫描,发现2个file# 5文件的起始位置(分别是block 2和block 0),而且结束位置文件大小分别是10G和5G,根据经验这两个连续的磁盘分配空间很可能就是这两个file# 5的文件
通过winhex把数据拷贝出来,使用工具检测

除损坏的block 1之外(block 0 不统计在内),其他block都正常,也就是说这个10G的被删除的数据文件,只是丢失一个文件头,业务数据全部再,后续通过dul恢复客户需要数据,完成这次数据恢复,类似这种文件丢失,文件系统损坏,文件大小为0kb等类似恢复,参见以前类似blog:
win文件系统损坏oracle恢复
dbca删除库和rm删库恢复
文件系统重新分区oracle恢复
restore database误操作恢复
文件系统损坏导致数据文件异常恢复
Oracle 数据文件大小为0kb或者文件丢失恢复
rm -rf 删除数据文件恢复方法—文件系统反删除+oracle碎片重组
ORA-600 ktbsdp2 处理
客户反馈数据库异常:两个节点rac,两个节点都启动,其中一个节点无法正常open,另外一个节点一段时间后也会挂。以下是无法正常open节点报错信息(正常open节点最终挂掉报错信息也是类似)
2022-03-30T19:19:12.870813+08:00 [84321] Successfully onlined Undo Tablespace 4. Undo initialization finished serial:0 start:1728252021 end:1728256302 diff:4281 ms (4.3 seconds) Verifying minimum file header compatibility for tablespace encryption.. Verifying file header compatibility for tablespace encryption completed for pdb 0 2022-03-30T19:19:13.953252+08:00 Database Characterset is ZHS16GBK 2022-03-30T19:19:14.538155+08:00 Errors in file /oracle/app/oracle/diag/rdbms/xff/xff2/trace/xff2_p02o_85718.trc (incident=1093927): ORA-00600: internal error code, arguments: [ktbsdp2], [18446744073709551615], [], [], [], [], [], [], [], [], [], [] Incident details in: /oracle/app/oracle/diag/rdbms/xff/xff2/incident/incdir_1093927/xff2_p02o_85718_i1093927.trc 2022-03-30T19:19:15.536582+08:00 ORACLE Instance xff2 (pid = 57) - Error 607 encountered while recovering transaction (73, 12) on object 112841. 2022-03-30T19:19:33.699944+08:00 Errors in file /oracle/app/oracle/diag/rdbms/xff/xff2/trace/xff2_smon_84007.trc: ORA-00607: Internal error occurred while making a change to a data block ORA-00600: internal error code, arguments: [ktbsdp2], [18446744073709551615], [], [], [], [], [], [], [], [], [], [] 2022-03-30T19:19:34.673840+08:00 Errors in file /oracle/app/oracle/diag/rdbms/xff/xff2/trace/xff2_smon_84007.trc: ORA-00607: Internal error occurred while making a change to a data block ORA-00600: internal error code, arguments: [ktbsdp2], [18446744073709551615], [], [], [], [], [], [], [], [], [], [] 2022-03-30T19:19:34.673954+08:00 Errors in file /oracle/app/oracle/diag/rdbms/xff/xff2/trace/xff2_smon_84007.trc: ORA-00607: Internal error occurred while making a change to a data block ORA-00600: internal error code, arguments: [ktbsdp2], [18446744073709551615], [], [], [], [], [], [], [], [], [], [] Errors in file /oracle/app/oracle/diag/rdbms/xff/xff2/trace/xff2_smon_84007.trc (incident=1092704): ORA-607 [] [] [] [] [] [] [] [] [] [] [] [] Incident details in: /oracle/app/oracle/diag/rdbms/xff/xff2/incident/incdir_1092704/xff2_smon_84007_i1092704.trc 2022-03-30T19:19:35.422779+08:00 ***************************************************************** An internal routine has requested a dump of selected redo. This usually happens following a specific internal error, when analysis of the redo logs will help Oracle Support with the diagnosis. It is recommended that you retain all the redo logs generated (by all the instances) during the past 12 hours, in case additional redo dumps are required to help with the diagnosis. ***************************************************************** 2022-03-30T19:19:36.154689+08:00 Starting background process GTX0 2022-03-30T19:19:36.169007+08:00 GTX0 started with pid=370, OS id=87409 2022-03-30T19:19:36.645876+08:00 USER (ospid: 84007): terminating the instance due to error 607 2022-03-30T19:19:36.680109+08:00 opiodr aborting process unknown ospid (87439) as a result of ORA-1092 2022-03-30T19:19:36.681091+08:00 ORA-1092 : opitsk aborting process 2022-03-30T19:19:36.740357+08:00 System state dump requested by (instance=2, osid=84007 (SMON)), summary=[abnormal instance termination]. System State dumped to trace file /oracle/app/oracle/diag/rdbms/xff/xff2/trace/xff2_diag_83895_20220330191936.trc 2022-03-30T19:19:40.135579+08:00 Instance terminated by USER, pid = 84007
对于上述报错信息分析,初步判断是由于事务异常导致,查询mos发现类似报错Bug 32208691 – After upgrade from 12.1 to 19.3 drop columns fails ORA-600[ktbsdp2] ORA-600[4512] (Doc ID 32208691.8),通过咨询客户,确认他们这边是通过plsql dev工具对id为112841表进行增加列的时候网络中断导致增加失败,后续我尝试对该表进行查询发现也报该错误,基本上可以确认由于该表事务异常导致,通过dul把该表数据恢复,然后drop 该表,数据库启动正常,未见其他报错,通过hcheck检查,数据库字典基本一致(除一些统计信息异常,原则上不影响数据库运行)
[oracle@xifenfei2 ~]$ sqlplus / as sysdba @hcheck.sql SQL*Plus: Release 12.2.0.1.0 Production on Thu Mar 31 00:38:32 2022 Copyright (c) 1982, 2016, Oracle. All rights reserved. Connected to: Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production HCheck Version 07MAY18 on 31-MAR-2022 00:38:34 ---------------------------------------------- Catalog Version 12.2.0.1.0 (1202000100) db_name: xff Is CDB?: NO Catalog Fixed Procedure Name Version Vs Release Timestamp Result ------------------------------ ... ---------- -- ---------- -------------- ------ .- LobNotInObj ... 1202000100 <= *All Rel* 03/31 00:38:34 PASS .- MissingOIDOnObjCol ... 1202000100 <= *All Rel* 03/31 00:38:34 PASS .- SourceNotInObj ... 1202000100 <= *All Rel* 03/31 00:38:34 PASS .- OversizedFiles ... 1202000100 <= *All Rel* 03/31 00:38:38 PASS .- PoorDefaultStorage ... 1202000100 <= *All Rel* 03/31 00:38:38 PASS .- PoorStorage ... 1202000100 <= *All Rel* 03/31 00:38:38 PASS .- TabPartCountMismatch ... 1202000100 <= *All Rel* 03/31 00:38:38 PASS .- OrphanedTabComPart ... 1202000100 <= *All Rel* 03/31 00:38:38 PASS .- MissingSum$ ... 1202000100 <= *All Rel* 03/31 00:38:38 PASS .- MissingDir$ ... 1202000100 <= *All Rel* 03/31 00:38:38 PASS .- DuplicateDataobj ... 1202000100 <= *All Rel* 03/31 00:38:40 PASS .- ObjSynMissing ... 1202000100 <= *All Rel* 03/31 00:38:42 PASS .- ObjSeqMissing ... 1202000100 <= *All Rel* 03/31 00:38:42 PASS .- OrphanedUndo ... 1202000100 <= *All Rel* 03/31 00:38:44 PASS .- OrphanedIndex ... 1202000100 <= *All Rel* 03/31 00:38:44 PASS .- OrphanedIndexPartition ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- OrphanedIndexSubPartition ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- OrphanedTable ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- OrphanedTablePartition ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- OrphanedTableSubPartition ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- MissingPartCol ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- OrphanedSeg$ ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- OrphanedIndPartObj# ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- DuplicateBlockUse ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- FetUet ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- Uet0Check ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- SeglessUET ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- BadInd$ ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- BadTab$ ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- BadIcolDepCnt ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- ObjIndDobj ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- TrgAfterUpgrade ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- ObjType0 ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- BadOwner ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- StmtAuditOnCommit ... 1202000100 <= *All Rel* 03/31 00:38:45 PASS .- BadPublicObjects ... 1202000100 <= *All Rel* 03/31 00:38:46 PASS .- BadSegFreelist ... 1202000100 <= *All Rel* 03/31 00:38:50 PASS .- BadDepends ... 1202000100 <= *All Rel* 03/31 00:38:50 PASS .- CheckDual ... 1202000100 <= *All Rel* 03/31 00:38:57 PASS .- ObjectNames ... 1202000100 <= *All Rel* 03/31 00:38:57 WARN HCKW-0018: OBJECT name clashes with SCHEMA name (Doc ID 2363142.1) Schema=MHWZ PACKAGE=MHWZ.MHWZ Schema=MHWZ PACKAGE BODY=MHWZ.MHWZ .- BadCboHiLo ... 1202000100 <= *All Rel* 03/31 00:39:01 WARN HCKW-0019: HIST_HEAD$.LOWVAL > HIVAL (Doc ID 1361047.1) OBJ# 324163 INTCOL#=22 OBJ# 482668 INTCOL#=4 OBJ# 442865 INTCOL#=31 OBJ# 436924 INTCOL#=31 OBJ# 580529 INTCOL#=8 OBJ# 459432 INTCOL#=31 OBJ# 451260 INTCOL#=31 OBJ# 530980 INTCOL#=21 OBJ# 498442 INTCOL#=5 OBJ# 652114 INTCOL#=8 OBJ# 701695 INTCOL#=21 OBJ# 831961 INTCOL#=31 OBJ# 831962 INTCOL#=31 OBJ# 831963 INTCOL#=31 .- ChkIotTs ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- NoSegmentIndex ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- BadNextObject ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- DroppedROTS ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- FilBlkZero ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- DbmsSchemaCopy ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- OrphanedIdnseqObj ... 1202000100 > 1201000000 03/31 00:39:09 PASS .- OrphanedIdnseqSeq ... 1202000100 > 1201000000 03/31 00:39:09 PASS .- OrphanedObjError ... 1202000100 > 1102000000 03/31 00:39:09 PASS .- ObjNotLob ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- MaxControlfSeq ... 1202000100 <= *All Rel* 03/31 00:39:09 PASS .- SegNotInDeferredStg ... 1202000100 > 1102000000 03/31 00:39:13 PASS .- SystemNotRfile1 ... 1202000100 > 902000000 03/31 00:39:13 PASS .- DictOwnNonDefaultSYSTEM ... 1202000100 <= *All Rel* 03/31 00:39:13 PASS .- OrphanTrigger ... 1202000100 <= *All Rel* 03/31 00:39:13 PASS .- ObjNotTrigger ... 1202000100 <= *All Rel* 03/31 00:39:13 PASS --------------------------------------- 31-MAR-2022 00:39:13 Elapsed: 39 secs --------------------------------------- Found 0 potential problem(s) and 16 warning(s) Contact Oracle Support with the output and trace file to check if the above needs attention or not PL/SQL procedure successfully completed. Statement processed. Complete output is in trace file: /oracle/app/oracle/diag/rdbms/xff/xff2/trace/xff2_ora_26887_HCHECK.trc