exp imp partition parallel 分区表导入导出 并行

Extremely slow performance is observed while running an Import DataPump (IMPDP) job against a highly partitioned table with 143 partitions. The import parameter file looks like:

TABLES=<SCHEMA_NAME>.<TABLE_NAME>:<PARTITION_NAME>

PARTITION_OPTIONS=DEPARTITION --对应下面一张nomal table名字

REMAP_TABLE=<SCHEMA_NAME>.<TABLE_NAME>:<PARTITION_NAME>:<TABLE_NAME>

CONTENT=ALL
SKIP_UNUSABLE_INDEXES=YES

DIRECTORY=EXPDP

DUMPFILE=<DUMP_NAME>_%U.dmp

LOGFILE=<LOG_NAME>.log

PARALLEL=8

DATA_OPTIONS=skip_constraint_errors

The SQL found in DW00 generated trace file has the following form:

INSERT /*+ APPEND PARALLEL("<table name>",<parallel degree>)+*/ INTO RELATIONAL("<schema name>"."<table name>") ...PARTITION <partition_name>

FROM "ET...." KU

The DataPump job was loading only approx 5% (or approx 5GB) per hour, on a 700GB table. The performance issue is introduced by the fact that the DML workers processes are not running in parallel even after setting up PARALLEL DML and PARALLEL=8.

Even if the parallel slaves are being launched:

PROGRAM COMMAND Username QC/Slave Slave Set SID SERIAL# QC SID REQ_DOP ACT_DOP

============================================================================================================

oracle <SERVICE_NAME> (P000) 2 - p000 (Slave) 1 787 10351 1044 8 8

oracle <SERVICE_NAME> (P001) 2 - p001 (Slave) 1 853 1203 1044 8 8

oracle <SERVICE_NAME> (P002) 2 - p002 (Slave) 1 915 50799 1044 8 8

oracle <SERVICE_NAME> (P003) 2 - p003 (Slave) 1 981 11441 1044 8 8

oracle <SERVICE_NAME> (DW00) 2 SYS QC 1044 56901 1044

oracle <SERVICE_NAME> (P000) 2 - p000 (Slave) 1 788 12009 1044 8 8

oracle <SERVICE_NAME> (P001) 2 - p001 (Slave) 1 850 50447 1044 8 8

oracle <SERVICE_NAME> (P002) 2 - p002 (Slave) 1 917 9857 1044 8 8

oracle <SERVICE_NAME> (P003) 2 - p003 (Slave) 1 980 39721 1044 8 8

the problem is that PARALLEL DML is disabled thus all of those parallel slaves are doing nothing on the INSERT. From below you can very clearly see that the PDML_STATUS is DISABLED:

INST_ID LOGON_TIME USERNAME STATUS PDML_STATUS PROGRAM SQL_ID

===================================================================================================

1 11/4/2014 16:17:03 A11P11 SYS ACTIVE ENABLED udi@<SERVICE_NAME> (TNS V1-V3) 7wn3wubg7gjds

2 11/4/2014 16:17:01 A11P11 SYS ACTIVE DISABLED oracle@<<SERVICE_NAME> (P001) asmy11x7ya7ws

2 11/4/2014 16:17:01 A11P11 SYS ACTIVE DISABLED oracle@<SERVICE_NAME>g (P000) asmy11x7ya7ws

2 11/4/2014 16:17:01 A11P11 SYS ACTIVE DISABLED oracle@<SERVICE_NAME> (P003) asmy11x7ya7ws

2 11/4/2014 16:17:01 A11P11 SYS ACTIVE DISABLED oracle@<SERVICE_NAME> (P002) asmy11x7ya7ws

1 11/4/2014 16:17:04 A11P11 SYS ACTIVE ENABLED oracle@<SERVICE_NAME> (DW00) asmy11x7ya7ws

1 11/4/2014 16:17:07 A11P11 SYS ACTIVE DISABLED oracle@<SERVICE_NAME> (P001) asmy11x7ya7ws

1 11/4/2014 16:17:07 A11P11 SYS ACTIVE DISABLED oracle@<SERVICE_NAME>g (P000) asmy11x7ya7ws

1 11/4/2014 16:17:07 A11P11 SYS ACTIVE DISABLED oracle@<SERVICE_NAME> (P003) asmy11x7ya7ws

1 11/4/2014 16:17:07 A11P11 SYS ACTIVE DISABLED oracle@<SERVICE_NAME> (P002) asmy11x7ya7ws

1 11/4/2014 16:17:04 A11P11 SYS ACTIVE ENABLED oracle@<SERVICE_NAME> (DM00) bjf05cwcj5s6p

As per worker trace, it is confirmed that the insert operation is loading data serially :


| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | TQ |IN-OUT| PQ Distrib |


| 0 | INSERT STATEMENT | | 8168 | 4817K| 4 (0)| 00:00:01 | | | |

| 1 | LOAD AS SELECT | <NAME> | | | | | | | |

| 2 | ERROR LOGGING | <NAME> | | | | | | | |

| 3 | PX COORDINATOR | | | | | | | | |

| 4 | PX SEND QC (RANDOM) | :TQ10000 | 8168 | 4817K| 4 (0)| 00:00:01 | Q1,00 | P->S | QC (RAND) |

| 5 | ERROR LOGGING QC (RANDOM) | :TQ10000 | | | 4 (0)| 00:00:01 | Q1,00 | PCWP | QC (RAND) |

| 6 | PX BLOCK ITERATOR | | 8168 | 4817K| 4 (0)| 00:00:01 | Q1,00 | PCWC | |

| 7 | EXTERNAL TABLE ACCESS FULL| ET$03D4837F0001 | 8168 | 4817K| 4 (0)| 00:00:01 | Q1,00 | PCWP | |


and the query coordinator(QC) is running alter session to enable the parallel dml:

KUPW:10:47:01.266: 0: ALTER SESSION ENABLE PARALLEL DML called.

KUPW:10:47:01.266: 0: ALTER SESSION ENABLE PARALLEL DML returned.

but as per PQ tracing the automatic degree of parallelism is disabled:

.....

kkfdtParallel: parallel is possible (no statement type restrictions)

kkfdPaPrm: use table level hint DOP(8) on table

kkfdPaPrm:- The table : 154053

kkfdPaPrm:DOP = 8 (computed from hint/dictionary/autodop)

kkfdiPaPrm: dop:8 parallel(?)

PDML disabled in session

kkfdtpddldml: isParallel ? No

This information shows that the insert is being serialized as a result of PARALLEL DML being disabled and the performance issue is introduced by this behavior.

CHANGES

CAUSE

This is an impdp performance issue where an import with external table access_method is not running the job in parallel even after starting the PQ slave correctly.

The performance issue is only hit when running the job with SYSDBA user. The root cause of this issue has been determined in Bug 19520061 - IMPDP: EXTREMELY SLOW IMPORT FOR A PARTITIONED TABLE.

SOLUTION

  1. Upgrade the database to 12.2, when available, where issue is fixed.
  • OR -
  1. For earlier database releases please check Patch 19520061, if available for your platform and RDBMS version.
  • OR -
  1. Run the DataPump import job with an user other than SYS.
相关推荐
石头wang14 小时前
oracle jdbc 依赖以及对dbeaver的性能影响,如何选择oracle驱动, oracle jdbc 驱动
数据库·oracle
-XWB-16 小时前
【Oracle】Oracle诊断系列(2/6):锁问题与阻塞分析——解决“卡住”的会话
数据库·oracle
cqsztech16 小时前
Oracle 26ai 2节点RAC 保姆级搭建步骤
数据库·oracle
知识分享小能手16 小时前
Oracle 19c入门学习教程,从入门到精通,Oracle 的闪回技术 — 语法知识点与使用方法详解(19)
数据库·学习·oracle
-XWB-18 小时前
【Oracle】Oracle诊断系列(4/6):表空间与对象管理——存储优化与空间规划
数据库·oracle
Apple_羊先森18 小时前
ORACLE数据库巡检SQL脚本--7、检查不起作用的约束
数据库·sql·oracle
-XWB-20 小时前
【Oracle】Oracle诊断系列(3/6):性能瓶颈定位——从SQL到I/O的全面分析
数据库·sql·oracle
猿小羽20 小时前
Spring Boot 2 + Flyway 最佳实践:多数据库配置与迁移规范
spring boot·mysql·postgresql·oracle·flyway·sql server·数据库迁移
是桃萌萌鸭~20 小时前
oracle 排查卡顿相关日志
数据库·oracle
Mr_Xuhhh1 天前
MySQL数据表操作全解析:从创建到管理
数据库·sql·oracle