如何对Oracle数据泵(expdp/impdp)进行debug


一.概述 我在之前写过2篇有关Oracle 数据泵的文章,如下: Oracle 10gData Pump Expdp/Impdp 详解 http://www.linuxidc.com/Li



一.概述
我在之前写过2篇有关Oracle 数据泵的文章,如下:

Oracle 10gData Pump Expdp/Impdp 详解

Oracleexpdp/impdp 使用示例

这两篇都是介绍数据泵的使用。

那么在实际的使用中,我们也会遇到一个问题,发生一些ORA-xx的错误,有具体的错误,我们都可以去google去分析,但是还有情况,就是也不错误,而是在某一步停住了,而且很长时间不动。

这是时候,我们是不好判断数据泵的操作是否正常。

在数据泵卡住的时候,有一个很好的方法来判断:

1. 在expdp的时候,我们要观察dump 文件的变化,只要dump 文件大小在变化,那就说明expdp是正常的。

2. 在impdp的时候,我们可以及时查看表空间的变化,只要我们的表空间在变化,说明我们的impdp是正常的。

如果在数据泵操作的时候,表空间和dump都没有变化,数据泵操作也停止在某一步不动。那么我们就只能对数据泵进行debug操作。

二.如何对数据泵进行debug?
trace 生成的文件可能很大,所以在进行trace之前,必须先检查dump文件的大小:max_dump_file_size。

[oracle@asm trace]$ orz param max_dump

Session altered.

NAME ISDEFAULT SESMO SYSMOD VALUE

---------------------- --------- -------------- ---------------

max_dump_file_size TRUE TRUE IMMEDIATE unlimited

如果不是unlimited,就进行修改:

ALTER SYSTEM SETmax_dump_file_size = unlimited SCOPE = both;

2.1 使用Data Pump的TRACE 参数
2.1.1 TRACE 说明
启动trace 功能只需要在expdp/impdp 命令后加上一个trace 参数,该参数由一个7位的16进制数据组成。

前三位指定Data Pump组件的代码,后四位一般是:0300。

任何已0开头的trace的值都会被忽略,trace值不区分大小写。

如:

TRACE = 04A0300 或者 TRACE=4a0300

trace值的一些注意事项:

(1) trace 值不要超过7位十六进制数字。

(2) 不要添加十六进制的0x符号。

(3) 不要将16进制转换成10进制。

(4) 会忽略最前面的0,即使长度不满足7位。

(5) 参数不区分大小写。

在使用trace 参数时,执行数据泵操作的用户需要具有DBA 角色或者EXP_FULL_DATABASE /IMP_FULL_DATABASE的角色,如果权限不足,就会报ORA-31631的错误。

ORA-31631: privileges are required

解决方法:给用户赋权。 如:

GRANT exp_full_database TO tianlesoftware;

操作完成之后,在收回权限即可:

revoke exp_full_database from tianlesoftware;

使用TRACE的示例:

expdp scott/tiger DIRECTORY=my_dir DUMPFILE=expdp_s.dmp LOGFILE=expdp_s.log TABLES=empTRACE=480300

2.1.2 TRACE值的具体计算规则

在前面我们讲了TRACE 值的前3位表示的是数据泵的组件代码,具体如下:

-- Summary of Data Pump trace levels:

-- ==================================

Trace DM DW ORA Lines

level trc trc trc in

(hex) file file file trace Purpose

------- ---- ---- ---- -----------------------------------------------------

10300 x x x SHDW: To trace the Shadowprocess (API) (expdp/impdp)

20300 x x x KUPV: To trace Fixed table

40300 x x x 'div' To trace Process services

80300 x KUPM: To trace Master ControlProcess (MCP) (DM)

100300 x x KUPF: To trace File Manager

200300 x x x KUPC: To trace Queue services

400300 x KUPW: To trace Workerprocess(es) (DW)

800300 x KUPD: To trace DataPackage

1000300 x META: To trace Metadata Package

--- +

1FF0300 x x x 'all' To trace all components (full tracing)

如果想trace 所有的数据泵组件,只需要指定trace的值为1ff0300即可。

如果我们想通知trace 多个数据泵组件,就把这些组件的代码叠加起来即可,,如:

-- Example of combination(last 4 digits are usually 0300):

40300 to trace Process services

80300 to trace Master Control Process (MCP)

400300 to trace Worker process(es)

-- +

4C0300 to trace Process services and MasterControl and Worker processes

叠加的时候,最后4位不变,把前面3位的值相加。

注意:

Oracle 建议使用480300的trace值,设置该值将会trace Master Control process (MCP) 和 theWorker process(es)。

2.1.3 TRACE 文件的log 位置
2个trace 文件在BACKGROUND_DUMP_DEST目录下:

Master Process trace file: _dm_.trc Worker Process trace file: _dw_.trc

还有一个在USER_DUMP_DEST目录:

Shadow Processtrace file: _ora_.trc

[oracle@asm u01]$ orzparam background

Session altered.

NAME ISDEFAULT SESMO SYSMOD VALUE

----------------------- --------- -------------- ----------------------------------------

background_core_dump TRUE FALSE FALSE partial

background_dump_dest TRUE FALSE IMMEDIATE /u01/app/oracle/diag/rdbms/dave/dave/trace

[oracle@asm u01]$ orzparam user_dump

Session altered.

NAME ISDEFAULT SESMO SYSMOD VALUE

--------------------- --------- -------------- ----------------------------------------

user_dump_dest TRUE FALSE IMMEDIATE/u01/app/oracle/diag/rdbms/dave/dave/trace

2.1.4 TRACE 使用示例
SQL> set lin 160 pages 200

SQL> col owner for a10

SQL> col DIRECTORY_PATH for a50

SQL> select * from dba_directories;

OWNER DIRECTORY_NAME DIRECTORY_PATH

---------- --------------------------------------------------------------------------------

SYS ORACLE_OCM_CONFIG_DIR /u01/app/oracle/11.2.0/db_1/ccr/state

SYS DATA_PUMP_DIR /u01/app/oracle/admin/dave/dpdump/

SYS XMLDIR /u01/app/oracle/11.2.0/db_1/rdbms/xml

SQL>

SQL> create directory backup as'/u01/backup';

Directory created.

SQL> select * from dba_directories;

OWNER DIRECTORY_NAME DIRECTORY_PATH

---------- --------------------------------------------------------------------------------

SYS ORACLE_OCM_CONFIG_DIR /u01/app/oracle/11.2.0/db_1/ccr/state

SYS DATA_PUMP_DIR /u01/app/oracle/admin/dave/dpdump/

SYS XMLDIR /u01/app/oracle/11.2.0/db_1/rdbms/xml

SYS BACKUP /u01/backup

--创建测试表:tianlesoftware:

SQL> conn system/oracle;

Connected.

SQL> create table tianlesoftware asselect * from dba_objects;

Table created.

--使用trace:480300进行导出:

[oracle@asm u01]$ expdp system/oracleDIRECTORY=backup DUMPFILE=dave.dmp LOGFILE=dave.log TABLES=tianlesoftwareTRACE=480300

Export: Release 11.2.0.3.0 - Production onMon May 27 19:50:49 2013

Copyright (c) 1982, 2011, Oracle and/or itsaffiliates. All rights reserved.

Connected to: Oracle Database 11gEnterprise Edition Release 11.2.0.3.0 - 64bit Production

With the Partitioning, Automatic StorageManagement, OLAP, Data Mining

and Real Application Testing options

Starting"SYSTEM"."SYS_EXPORT_TABLE_01": system/******** DIRECTORY=backupDUMPFILE=dave.dmp LOGFILE=dave.log TABLES=tianlesoftware TRACE=480300

Estimate in progress using BLOCKS method...

Processing object typeTABLE_EXPORT/TABLE/TABLE_DATA

Total estimation using BLOCKS method: 9 MB

Processing object typeTABLE_EXPORT/TABLE/TABLE

Processing object typeTABLE_EXPORT/TABLE/PRE_TABLE_ACTION

. . exported"SYSTEM"."TIANLESOFTWARE" 7.215 MB 74608 rows

Master table"SYSTEM"."SYS_EXPORT_TABLE_01" successfully loaded/unloaded

******************************************************************************

Dump file set for SYSTEM.SYS_EXPORT_TABLE_01is:

/u01/backup/dave.dmp

Job"SYSTEM"."SYS_EXPORT_TABLE_01" successfully completed at19:51:22

--查看trace文件:

-rw-r----- 1 oracle asmadmin 1433 May 27 19:51 dave_dw00_7486.trm

-rw-r----- 1 oracle asmadmin 32109 May 27 19:51 dave_dw00_7486.trc

-rw-r----- 1 oracle asmadmin 1417 May 27 19:51 dave_dm00_7484.trm

-rw-r----- 1 oracle asmadmin 25025 May 27 19:51 dave_dm00_7484.trc

-rw-r----- 1 oracle asmadmin 2908 May 27 19:50 dave_ora_7480.trc

[oracle@asm trace]$ head -50 dave_dw00_7486.trc

Trace file/u01/app/oracle/diag/rdbms/dave/dave/trace/dave_dw00_7486.trc

Oracle Database 11g Enterprise EditionRelease 11.2.0.3.0 - 64bit Production

With the Partitioning, Automatic StorageManagement, OLAP, Data Mining

and Real Application Testing options

ORACLE_HOME = /u01/app/oracle/11.2.0/db_1

System name: Linux

Node name: asm

Release: 2.6.32-100.34.1.el6uek.x86_64

Version: #1 SMP Wed May 25 17:46:45 EDT 2011

Machine: x86_64

Instance name: dave

Redo thread mounted by this instance: 1

Oracle process number: 42

Unix process pid: 7486, image: oracle@asm(DW00)

*** 2013-05-27 19:50:55.052

*** SESSION ID:(24.127) 2013-05-2719:50:55.052

*** CLIENT ID:() 2013-05-27 19:50:55.052

*** SERVICE NAME:(SYS$BACKGROUND) 2013-05-2719:50:55.052

*** MODULE NAME:() 2013-05-27 19:50:55.052

*** ACTION NAME:() 2013-05-27 19:50:55.052

KUPP:19:50:55.051: Current trace/debugflags: 00480300 = 4719360

*** MODULE NAME:(Data Pump Worker)2013-05-27 19:50:55.054

*** ACTION NAME:(SYS_EXPORT_TABLE_01)2013-05-27 19:50:55.054

KUPW:19:50:55.054: 0: ALTER SESSION ENABLEPARALLEL DML called.

KUPW:19:50:55.054: 0: ALTER SESSION ENABLEPARALLEL DML returned.

KUPC:19:50:55.098: Setting remote flag forthis process to FALSE

prvtaqis - Enter

prvtaqis subtab_name upd

prvtaqis sys table upd

KUPW:19:50:55.665: 0: KUPP$PROC.WHATS_MY_IDcalled.

KUPW:19:50:55.665: 1: KUPP$PROC.WHATS_MY_IDreturned.

KUPW:19:50:55.666: 1: worker max messagenumber: 1000

KUPW:19:50:55.668: 1: Full cluster accessallowed

KUPW:19:50:55.669: 1: Original job starttime: 13-MAY-27 07:50:51 PM

KUPW:19:50:55.671: 1: Seqno 16 isTABLE_EXPORT/TABLE/TABLE_DATA

KUPW:19:50:55.671: 1: Seqno 63 isTABLE_EXPORT/TABLE/INDEX/TABLE_DATA

KUPW:19:50:55.671: 1:KUPP$PROC.WHATS_MY_NAME called.

KUPW:19:50:55.671: 1:KUPP$PROC.WHATS_MY_NAME returned. Process name: DW00

KUPW:19:50:55.671: 1:KUPV$FT_INT.GET_INSTANCE_ID called.

KUPW:19:50:55.674: 1:KUPV$FT_INT.GET_INSTANCE_ID returned. Instance name: dave

KUPW:19:50:55.679: 1: ALTER SESSION ENABLERESUMABLE called.

KUPW:19:50:55.679: 1: ALTER SESSION ENABLERESUMABLE returned.

KUPW:19:50:55.682: 1: KUPF$FILE.INITcalled.

KUPW:19:50:55.883: 1: KUPF$FILE.INITreturned.

KUPW:19:50:55.886: 1:KUPF$FILE.GET_MAX_CSWIDTH called.

KUPW:19:50:55.886: 1:KUPF$FILE.GET_MAX_CSWIDTH returned.

[oracle@asm trace]$

[oracle@asm trace]$ head -50 dave_dm00_7484.trc

Trace file/u01/app/oracle/diag/rdbms/dave/da

  • 濡備綍鍦oracle涓鍑,瀵煎叆鏁版嵁
    绛旓細鐒跺悗鎵ц杩欎簺淇敼璇彞锛屽鎵鏈夌┖琛ㄥ垎閰嶇┖闂淬傛鏃剁敤exp鍛戒护锛屽彲灏嗗寘鎷┖琛ㄥ湪鍐呯殑鎵鏈夎〃瀵煎嚭銆備簩銆佸埄鐢╡xpdp impdp瀵煎嚭瀵煎叆 鍦Oracle10g涓璭xp imp琚噸鏂拌璁′负Oracle Data Pump锛堜繚鐣欎簡鍘熸湁鐨 exp imp宸ュ叿锛鏁版嵁娉涓庝紶缁熷鍑哄鍏ョ殑鍖哄埆;1) exp鍜宨mp鏄鎴风宸ュ叿锛屼粬浠棦鍙互鍦ㄥ鎴风浣跨敤锛屼篃鍙互鍦ㄦ湇鍔$...
  • Oracle 鏁版嵁娉 expdp瀵煎嚭logfile涓嶅畬鏁,鎬庢牱璁╁鍑虹殑鏁版嵁瀹屾暣,鎴栨寜杩欎釜...
    绛旓細涓嶆槸娌℃湁浜嗭紝鏄鍦ㄥ鍑猴紝鍥犱负鏂囦欢寰堝ぇ锛岃繖閲岀湅鏄2.041 GB锛屾墍浠ュ鍑洪渶瑕佹椂闂达紝瀵煎嚭瀹屾垚鍚庝細鏈夊鍑烘垚鍔熷瓧鏍凤紝鎴栬呭鍑烘垚鍔熸垨鏈夐棶棰橈紝鎴栬呭鍑轰笉鎴愬姛锛屼綘鐜板湪杩欎釜灏辨槸杩樻病瀵煎畬锛屼綘澶潃鎬ヤ簡銆傚鏋滃鍑烘垚鍔燂紝閭d箞瀵煎叆鏄病鏈夐棶棰樼殑锛屽綋鐒跺彲鑳介渶瑕佸缓绔嬬敤鎴蜂粈涔堢殑锛屾垜閬囧埌杩囧鍏ユ椂鎶ユ病鏈夌敤鎴凤紝娌℃湁琛ㄧ┖闂磋繖绫...
  • 鍏充簬oracle鐨瀵煎叆瀵煎嚭闂
    绛旓細妤间笂璇寸殑宸茬粡宸笉澶氫簡锛屼笉杩囧湪鎿嶄綔涓偗瀹氫細鍑虹幇鎶ラ敊闂锛岄渶瑕佹繁鍏ュ幓瀛︿範oracle鐨勮鍒欍Oracle鏁版嵁瀵煎叆瀵煎嚭imp/exp灏辩浉褰撲簬oracle鏁版嵁杩樺師涓庡浠姐俥xp鍛戒护鍙互鎶婃暟鎹粠杩滅▼鏁版嵁搴撴湇鍔″櫒瀵煎嚭鍒版湰鍦扮殑dmp鏂囦欢锛宨mp鍛戒护鍙互鎶奷mp鏂囦欢浠庢湰鍦板鍏ュ埌杩滃鐨勬暟鎹簱鏈嶅姟鍣ㄤ腑銆 鍒╃敤杩欎釜鍔熻兘鍙互鏋勫缓涓や釜鐩稿悓鐨勬暟鎹簱锛...
  • oracle鎬庢牱缁堟鏁版嵁娉expdp瀵煎嚭鍛? expdp绐楀彛琚叧鎺変簡,涓嶈兘鐢╟trl+c...
    绛旓細閲嶆柊鎵撳紑expdp 杈撳叆CONTINUE_CLIENT锛孍XPDP鏃犳硶缁堟锛岄櫎闈炴姤閿欙紝鍥犱负浠栨槸涓涓湇鍔″櫒绔伐鍏枫
  • oracle 鏁版嵁娉鍜宔xp鐨勫尯鍒
    绛旓細exp imp 鍦ㄨ繛鎺ュ埌鏁版嵁搴撶殑鐢佃剳涓婇兘鑳芥墽琛岋紝鏄緢鏃╁氨鏈夌殑鍔熻兘 鏁版嵁娉鏄柊鍔熻兘锛屾槸exp imp鐨勫寮猴紝璇硶锛岄熷害鍧囨湁澧炲己锛屾槸10g浠ュ悗鎵嶆湁鐨勫姛鑳斤紝鍙兘鍦ㄦ暟鎹簱鐨勭數鑴戜笂鎵ц锛屽畨鍏ㄦф洿楂樸備笉鍚屾儏鍐电敤涓嶅悓鍔熻兘锛岀畝鍗曚娇鐢紝鏁伴噺涓嶅ぇ鏃讹紝鍙敤 exp imp 鏁版嵁娉垫洿濂斤紝鏇村己澶 ...
  • oracle Expdp鍛戒护鐨 exclude 鍙傛暟鎬庝箞浣跨敤
    绛旓細Export: Release 10.2.0.5.0 - 64bit Production on 鏄熸湡鏃, 12 4鏈, 2015 16:22:28 Copyright (c) 2003, 2007, Oracle. All rights reserved.鏁版嵁娉瀵煎嚭瀹炵敤绋嬪簭鎻愪緵浜嗕竴绉嶇敤浜庡湪 Oracle 鏁版嵁搴撲箣闂翠紶杈 鏁版嵁瀵硅薄鐨勬満鍒躲傝瀹炵敤绋嬪簭鍙互浣跨敤浠ヤ笅鍛戒护杩涜璋冪敤:绀轰緥: expdp scott/tiger ...
  • Oracle鍒╃敤鏁版嵁娉靛浣璁〢鐢佃剳鏁版嵁搴撳鎴风灏咮鏁版嵁搴撴湇鍔″櫒鏁版嵁澶囦唤鍒癈...
    绛旓細瀵鏁版嵁 [oracle11g@rhel4 admin]$ expdp system/oracle directory=dump dumpfile=scott_test.dmp logfile=scott_log.dmp network_link='power1' schemas=scott Export: Release 11.2.0.3.0 - Production on Tue Mar 26 18:22:28 2013 Copyright (c) 1982, 2011, Oracle and/or its ...
  • oracle 11g 鏁版嵁娉瀵煎叆瀵煎嚭(expdp impdp)鎵ц鍛戒护鏃跺崱姝,涓嶆姤閿欎篃涓...
    绛旓細鍥犱负oracle鏄洰鍓 鎴戜滑鎵鐢ㄧ殑鍑犱箮鏈澶х殑鏁版嵁搴擄紝瀹冩墍鍗犵敤鐨勫唴瀛樻槸闈炲父澶х殑锛屾墍浠 浣犲湪瀵煎叆澶ч噺鐨勬暟鎹殑鏃跺欙紝寰堟湁鍙兘 涔熶細鍗犵敤澶ч噺鐨勫唴瀛橈紝濡傛灉浣犵殑鐢佃剳鏈韩鍐呭瓨姣旇緝灏忥紝杩欐牱鐨勫崰鐢ㄩ噺 纭疄浼氳浣犵殑鐢佃剳姝绘満銆
  • oracle鏁版嵁搴撳浣澶囦唤涓庢仮澶
    绛旓細鐑浠芥槸鎸囧湪鏁版嵁搴撳紑鍚苟澶勪簬褰掓。妯″紡涓瀵鏁版嵁鏂囦欢杩涜鎷疯礉銆傜儹澶囦唤鐨勪紭鐐规槸涓嶉渶瑕佸仠鏈虹淮鎶わ紝涓嶅奖鍝嶄笟鍔¤繛缁э紝缂虹偣鏄瘮杈冨鏉傘佽楁椂銆佸崰鐢ㄨ祫婧愩傚鍏ュ鍑烘槸鎸囦娇鐢‥XP/IMP鎴栬鏁版嵁娉鎶鏈皢鏁版嵁搴撲腑鐨勫璞℃垨鑰呮暟鎹鍑哄埌涓涓簩杩涘埗鏂囦欢涓紝骞朵笖鍙互灏嗚繖涓枃浠跺鍏ュ埌鍙︿竴涓暟鎹簱涓傚鍏ュ鍑虹殑浼樼偣鏄伒娲汇...
  • 鎯虫妸oracle10g鐨勬暟鎹,鐢鏁版嵁娉瀵煎嚭,瀵煎叆鍒12C涓,缁鎬庝箞鍐欏鍑鸿鍙鐧 ...
    绛旓細sqlplus / as sysdba 鍦╯qlplus閲屾墽琛 create directory backup as '/data/oracle/oradata/mydata';--杩欓噷閫夋嫨涓涓枃浠跺す瀛樻斁dmp鏂囦欢 grant read,write on directory backup to system;閫鍑哄埌linux缁堢鎴杦indos cmd鎵ц expdp systemtest directory=backup dumpfile=test.dmp logfile=test.log consistent...
  • 扩展阅读:数据泵impdp使用教程 ... oracle数据库11g安装教程 ... oracle数据库入门教程 ... 数据泵导入 ... 数据泵导入覆盖原数据 ... oracle数据迁移脚本 ... oracle下载安装详细教程 ... oracle官网使用教程 ... oracle数据泵导入导出整库 ...

    本站交流只代表网友个人观点,与本站立场无关
    欢迎反馈与建议,请联系电邮
    2024© 车视网