客户一套nc系统,由于安装时候把库建在了比较小的分区上,运行一些时间之后,出现空间不足,现场技术人员对oracle不太熟悉,经过一系列操作(删除业务表空间,复制pdb,创建表空间等等操作),无法恢复数据库,准备使用备份的dmp进行还原,结果分析发现仅保留的最后一份dmp,是一份导出不完全的dmp文件,无法正常导入(以前处理过一个类似case:ORA-39773: parse of metadata stream failed故障处理,尝试导入报ORA-39246错:
C:\Users\XFF>impdp system/oracle@127.0.0.1/orapdb directory=expdp_dir dumpfile=xxxxx_2025-12-01_0230.dmp logfile=1.logImport: Release 19.0.0.0.0 - Production on 星期三 12月 3 21:00:19 2025Version 19.3.0.0.0Copyright (c) 1982, 2019, Oracle and/or its affiliates. All rights reserved.连接到: Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - ProductionORA-39002: 操作无效ORA-39059: 转储文件集不完整ORA-39246: 无法在提供的转储文件中定位主表 |
分析当时当初的dmp日志,由于expdp的job表所在表空间不足导致expdp导出失败
TABLE:"XIFENFEI"."EOM_MEASURE_POINT"ORA-30032: 挂起的 (可恢复) 语句已超时ORA-01691: Lob 段 XIFENFEI.SYS_LOB0000161267C00111$$ 无法通过 32 (在表空间 NNC_DATA01 中) 扩展ORA-06512: 在 "SYS.DBMS_SYS_ERROR", line 105ORA-06512: 在 "SYS.KUPW$WORKER", line 12620ORA-06512: 在 "SYS.DBMS_SYS_ERROR", line 105ORA-06512: 在 "SYS.KUPW$WORKER", line 11414----- PL/SQL Call Stack ----- object line object handle number name0xda5dae50 33476 package body SYS.KUPW$WORKER.WRITE_ERROR_INFORMATION0xda5dae50 12641 package body SYS.KUPW$WORKER.DETERMINE_FATAL_ERROR0xda5dae50 11602 package body SYS.KUPW$WORKER.CREATE_OBJECT_ROWS0xda5dae50 15268 package body SYS.KUPW$WORKER.FETCH_XML_OBJECTS0xda5dae50 3907 package body SYS.KUPW$WORKER.UNLOAD_METADATA0xda5dae50 13736 package body SYS.KUPW$WORKER.DISPATCH_WORK_ITEMS0xda5dae50 2429 package body SYS.KUPW$WORKER.MAIN0x6524a4f0 2 anonymous blockKUPW: Object row index into parse items is: 1KUPW: Parse item count is: 19KUPW: In function CHECK_FOR_REMAP_NETWORKKUPW: Nothing to remapKUPW: In procedure BUILD_OBJECT_STRINGS - non-base infoKUPW: In procedure BUILD_SUBNAME_LIST with TABLE:XIFENFEI.EOM_MEASURE_POINTKUPW: In function NEXT_PO_NUMBERKUPW: PO number assigned: 34198FORALLKUPW: In procedure DETERMINE_FATAL_ERROR with ORA-30032: 挂起的 (可恢复) 语句已超时ORA-01691: Lob 段 XIFENFEI.SYS_LOB0000161267C00111$$ 无法通过 32 (在表空间 NNC_DATA01 中) 扩展作业 "XIFENFEI"."SYS_EXPORT_SCHEMA_01" 因致命错误于 星期一 12月 1 06:33:21 2025 elapsed 0 04:03:18 停止 |
从导出日志看,在导出大量”0 KB 0 行”记录之后提示表空间不足,expdp的job表无法扩展导致导出挂起然后超时导出终止(这个导出操作没有完全完成),从而在导入的时候出现了ORA-39059: 转储文件集不完整 ORA-39246: 无法在提供的转储文件中定位主表 的错误.对于这种故障,分析导出日志,发现运气不错,所有有数据的表都导出完成,基于这个心中就有了第一层底气,所有表数据不会丢失(因为都导出到了这个dmp中),但是非表的字典数据不完整,要想业务完整跑起来,需要找到一个完整的业务字典信息.对于大量的备份dmp被删除,然后对应分区还写入了很多数据,只能尝试看运气,通过对磁盘文件镜像,然后进行反删除恢复,找出来一个11月26日的dmp的压缩文件是完整的
通过这个dmp导入业务字典信息,然后再利用expdp dmp解析工具(expdp dmp被加密破坏恢复)把所有表数据出来,经过这两者组合,顺利完成数恢复,可以测试业务完全正常
浙公网安备 33010602011771号