Impdp因致命錯誤終止 ORA-7445 [kpodpals]
背景
接到客戶反饋,用戶把生產NC數據庫導出之后,在測試庫無法成功導入。在導入過程中遇到錯誤被終止。錯誤代碼是ORA-7445[kpodpals],由于提供的信息量比較少,剛開始沒有頭緒,這個問題處理起來還是挺麻煩的。
問題分析
步驟一:分析跟蹤日志信息
通過對跟蹤日志的分析,查看問題的故障點。通過分析跟蹤日志,查找問題出現的原因。跟蹤日志文件,內容具體如下:
步驟二:通過故障代碼的分析,查找ORACLE官方相關文檔。
通過對跟蹤日志的分析,我們發現ORACLE 報ORA-07445 [kpodpals()+5174],我們這里就抓住ORA-07445 [kpodpals()+5174]不放,這種核心錯誤,一般99%是Oracle的BUG引起,通過Oracle的官方信息,果然發現了一篇文檔:
ORA-7445 [kpodpals] During DataPump Import (文檔 ID 1096837.1)
SYMPTOMSYou perform a DataPump import and this breaks with errors:
#> impdp system/password directory=dpu dumpfile=a_table.dmp table_exists_actinotallow=replace
Import: Release 10.2.0.1.0 - Production on Wednesday, 21 April, 2010 9:21:43
Copyright (c) 2003, 2005, Oracle. All rights reserved.
Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options
Master table "SYSTEM"."SYS_IMPORT_FULL_01" successfully loaded/unloaded
Starting "SYSTEM"."SYS_IMPORT_FULL_01": system/******** directory=dpu
dumpfile=a_table.dmp table_exists_actinotallow=replace
Processing object type TABLE_EXPORT/TABLE/TABLE
Processing object type TABLE_EXPORT/TABLE/TABLE_DATA
ORA-39014: One or more workers have prematurely exited.
ORA-39029: worker 1 with process name "DW01" prematurely terminated
ORA-31672: Worker process DW01 died unexpectedly.
Job "SYSTEM"."SYS_IMPORT_FULL_01" stopped due to fatal error at 09:23:32
CAUSEThis is addressed in Bug 9626756. A no-name column "<space>" is included in the table definition.
The imported table is defined as:
create table a_table
(
id number,
" " varchar2(10), -- " " means "<one space>"
text varchar2(10)
);SOLUTION1. Don't use columns like "<space>" in the source database
- OR -
2. If a table has such columns, then exclude the table during import with:
exclude=table:\"IN ('A_TABLE')\"
原因就是有表的字段是空格,坑啊,居然有這么創建表的,接下來我們就要查詢下我們系統中是否真的存在這樣的表。
解決方案
步驟一:查詢表字段
通過上述SQL語句,一查詢果然有空格字段,帶有空格字段的表,具體如上圖所示。真是害死人啊。步驟二:排除表重新導入有兩種方式解決:
1.在正式庫中對表進行調整或者重建,
2.導入的時排除問題表,經過溝通決定采用第二種方法,排除表
總結
1、添加日志跟蹤文件是分析錯誤的重要途徑。數據泵日志跟蹤:通過在導出導入時,添加trace參數,產生跟蹤日志文件
2、ORA-7445 [kpodpals]: Bug 9626756.在一個表中包含一個沒有名字的全是空格的字段。