If you use RAC with two or more nodes and some of your TABLES or INDEXES have a "DEFAULT" value for DEGREE and INSTANCES parameters then you have troubles :).
To check if you have "DEFAULT" values for tables / indexes:
SELECT TABLE_NAME, OWNER, DEGREE, INSTANCES
FROM DBA_TABLES WHERE INSTANCES = 'DEFAULT';
SELECT INDEX_NAME,TABLE_NAME, OWNER, DEGREE, INSTANCES
FROM DBA_INDEXES WHERE INSTANCES = 'DEFAULT';
Oracle calculates DEFAULT degree of parallelism for a query by multiply the following instance parameters:
for 3 nodes RACs with 16 cores per node:
parallel_server_instances = 3
cpu_count=16
parallel_threads_per_cpu=2
So we have DEGREE= 16* 2 * 3 = 96 !!!
Here is the example of performance difference for simple query:
SQL> select degree,instances from user_indexes where index_name='IDX_TEST_2312';
DEGREE INSTANCES
-------------- -----------------
DEFAULT DEFAULT
1. The query use degree with level 96.
data:image/s3,"s3://crabby-images/7199a/7199ae1d0a2f9255fce6eab4805401dbf7176aed" alt=""
2. The same query but with the hint to set the degree to 1.
So keep an eye the "DEFAULT" value for your tables / indexes if you use RAC with more then one node.
That is all!
No comments:
Post a Comment