oracle分区表扩分区 很慢,expdp 分区表很慢

aix oracle 12.1.0.2 expdp评估8G,实际导出200M,耗时7小时,很慢。

处理思路:

先查等待事件,发现StreamsAQ: enqueue blocked on low memory事件,

查mos,发现相关文章

以下是expdp logtime = all命令的示例症状。(logtime 参数在 12.1 及以上版本可用)

导出空分区表需要0-3秒才能导出每个分区,而正常时通常需要不到一秒的时间。

在Auto SGA环境(设置了sga_target或memory_target)下,当 buffer cache 负载较高并且 streams pool 中的内存正被移动到 buffer cache 时,可能会发生此问题。

如果遇到类似的性能问题时,请检查以下查询是否一直返回“1”。该值表示 streams pool 处于收缩阶段。当 streams pool 完成收缩时,该值应返回“0”,但如果它一直返回“1”,则您可能遇到此问题。

SQL> select shrink_phase_knlasg from X$KNLASG;

SHRINK_PHASE_KNLASG

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

1

原因是

即使 streams pool 已经结束收缩,该标志也没有被修改,这导致各种 stream pool 操作(例如数据泵的内部操作)等待 "StreamsAQ: enqueue blocked on low memory"。

该问题是由于Bug 27634991引起的,在版本19.1及更高版本中修复了该问题。

解决:

如果由于“StreamsAQ: enqueue blocked on low memory”等待事件导致expdp / impdp命令出现严重性能问题,并且X$KNLASG.SHRINK_PHASE_KNLASG 列保持返回1并持续几分钟,则从sqlplus运行以下命令强制streams pool缩小完成。

connect / as sysdba

alter system set events 'immediate trace name mman_create_def_request level 6';

可以应用Patch 27634991以防止发生此问题。

如果您的问题不只是性能变差,而是在 "StreamsAQ: enqueue blocked on low memory" 等待中hang或spin,则可能是以下错误之一所引起。

Session hangs on "Streams AQ: enqueue blocked on low memory"

High CPU usage for Background q0 processes with fix for bug 21286665

设置events后,6分钟导出完。

WnHZ4wwQAMwAAMwAAMwAAMwAAMwAAMwAAMwMD1MoCxibGJsQkDMAADMAADMAADMAADMAADMAADMAADMAADh2Ngztj8fz18QVZNOg1jAAAAAElFTkSuQmCC

97k的一个小补丁

参考:

由于频繁等待 ”Streams AQ: Enqueue Blocked On Low Memory" 而导致Datapump Expdp或Impdp变慢 (Doc ID 2469587.1)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值