Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1118582
  • 博文数量: 231
  • 博客积分: 2500
  • 博客等级: 少校
  • 技术积分: 2662
  • 用 户 组: 普通用户
  • 注册时间: 2009-11-03 16:35
个人简介

学无止境

文章分类

全部博文(231)

文章存档

2014年(7)

2013年(103)

2011年(11)

2010年(53)

2009年(57)

分类: Oracle

2010-02-23 14:08:27

本文给出一些意见用于在数据库层面减少"PX Deq Credit: need buffer"和"PX Deq Credit: send blkd"等待事件。
PX等待事件发生在并行查询的不同进程之间交互数据或信息时。
有至少3个不同的主要原因导致该等待:
1.看到有大量的不同进程之间的数据和信息的交互导致高等待。原因可能是一个比较糟糕的执行计划用于了并行执行。
2.等待是由于资源的问题,如CPU或相互连接等。例如CPU利用率达到100%,进程达到了CPU的限制,而不能足够快地发送数据。
3.由于并行查询hang住,如等待事件为"PX Deq Credit: need buffer"。

本文不讨论关于2和3的两个原因。
1)并行度的设置
在数据库级,通常需要检查这个并行执行的设置。检查对象是否有并行度的设置。例如通过"alter index rebuild parallel 4;"语句会导致某个索引的并行度为4,但是目的仅是通过并行度4来重建索引,而不回改变并行度。
最好运行下面这篇文章的SQL命令:
Note.270837.1  Report for the Degree of Parallelism on Tables and Indexes 
该脚本的第4个命令将会显示不适当的索引或表的DOP。下面是一个输出的例子:
OWNER  TABLE_NAME   DEGREE  INSTANCES INDEX_NAME   DEGREE  INSTANCES
------ ------------ ------- --------- ------------ ------- ---------
SCOTT  DEPT         1       1         PK_DEPT      4    1
SCOTT  EMP          1       1         PK_EMP       DEFAULT DEFAULT
可以看到索引PK_DEPT和PK_EMP设置有并行度,但是它们的基础表没有。这时就该考虑改变索引的并行度设置为没有并行度。
alter index SCOTT.PK_DEPT noparallel;
第2个脚本用于显示schema中的DOP的描述概要。下面是一个输出的例子:
OWNER  DEGREE     INSTANCES  Num Tables  'PARALLE
------ ---------- ---------- ----------  --------
OSS    1          1                  126 Serial
OSS    8          1                   1  Parallel
可以看到在schema OSS中只有1张表的并行度为8。可能该表不需要设置DOP为8,可以考虑将该表设置为非并行,查找该表可以通过下面这个SQL:
select table_name from all_tables
where ( trim(degree) != '1' and trim(degree) != '0' ) or  
      ( trim(instances) != '1' and trim(instances) != '0' )
      and owner = 'OSS';
输出的结果:
TABLE_NAME
------------------------------
OSS_EMP
设置为非并行:
alter table OSS.OSS_EMP noparallel;
以上的方法就是通过减少并行查询的数量来减少数据的交互。
通常索引或表小于200 MB,不需要设置并行度。

有时可以增大参数PARALLEL_EXECUTION_MESSAGE_SIZE=8k或16k,但这会要求更多的"PX msg pool"。该pool可以通过下面这个查询监控:
select * from v$sgastat where upper(name)  like 'PX%';
阅读(1405) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~