oracle加并行变慢,并行设置不当导致数据处理速度变慢

在从4CPU单节点系统迁移到32CPU RAC系统后,发现特定数据处理速度反而变慢。分析发现是由于表SAVE_POINT_CACHE的默认并行度设置过高(64),在数据量很少的情况下造成大量等待事件如'PX Deq Credit: send blkd'和'PX Deq: reap credit'。关闭表的并行度后,处理速度在新旧系统中分别提升至1.60秒和1.14秒,问题得到解决。
摘要由CSDN通过智能技术生成

问题描述

系统迁移,由单节点4cpu服务器迁移到双节点rac,32颗cpu系统中,迁移后对特定数据新服务器的处理速度反而不如老服务器。

问题分析

出现两侧代码相同但执行结果相差很大的原因是表SAVE_POINT_CACHE并行度的设置

表SAVE_POINT_CACHE中数据非常少,只有几十条

在系统中表SAVE_POINT_CACHE的并行度设置为default

根据oracle对并行度的算法

Default = parallel_threads_per_cpu * cpu_count

我们系统中两边的设置都是如下的情况

NAMETYPEVALUE

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

parallel_threads_per_cpuinteger2

也就是每个cpu的并行度为2

老系统中系统共有4颗cpu

prtdiag -v结果片段

========================= CPUs

RunE$CPUCPU

BrdCPUMHzMB Impl.Mask

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

A0, 16 1500 32.0 US-IV+2.4

B1, 17 1500 32.0 US-IV+2.4

A2, 18 1500 32.0 US-IV+2.4

B3, 19 1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值