473,396 Members | 2,033 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,396 software developers and data experts.

type-2 index causing performance hit

We are using DB2 UDB version 8.1 fp7 & fp9 on AIX 5.2.
On our databases we do massive inserts and deletes (millions of rows).
The performance is dramatically reduced because of pseudo deleted keys.
In a 10 minutes it goes from 18000 transaction per minute to 9000 and
lower.
When an index reorg with CLEANUP ONLY PAGES is executed, the number of
transactions climbs again. But a few minutes later it drops again to
9000.
We have to run the reorg constantly to keep a steady speed.

I'm thinking of using the option minpctused on all indexes.
But how do you specify this when constraints like primary keys are
used?
Are there other options we can use to keep a steady performance.

Jan 2 '06 #1
12 3031
<be**************@gmail.com> wrote in message
news:11*********************@g14g2000cwa.googlegro ups.com...
We are using DB2 UDB version 8.1 fp7 & fp9 on AIX 5.2.
On our databases we do massive inserts and deletes (millions of rows).
The performance is dramatically reduced because of pseudo deleted keys.
In a 10 minutes it goes from 18000 transaction per minute to 9000 and
lower.
When an index reorg with CLEANUP ONLY PAGES is executed, the number of
transactions climbs again. But a few minutes later it drops again to
9000.
We have to run the reorg constantly to keep a steady speed.

I'm thinking of using the option minpctused on all indexes.
But how do you specify this when constraints like primary keys are
used?
Are there other options we can use to keep a steady performance.

Create an unique index with the attributes you want prior to creating the PK
(create the PK with an alter table).

I doubt that minpctused used will help. In fact it may make it worse since
it will attempt to reorg the index pages online while your are inserting and
deleting.

I would suggest using a high percent free value (25-30%) for the indexes.
Other options include using the load command.
Jan 2 '06 #2
Thanks for the tip and suggestions.
I'll try the high percent free value, but the load is not possible. The
application (not ours) just works this way.
I hope one of the options will work, cause else I must say DB2 is not
build for high transaction volumes we are doing and that would be very
sad.
I read about the benefits from type-2 indexes, but there seems to be a
big drawback because it reduce the efficiency of the index big time in
our situation.

Jan 2 '06 #3
<be**************@gmail.com> wrote in message
news:11**********************@o13g2000cwo.googlegr oups.com...
Thanks for the tip and suggestions.
I'll try the high percent free value, but the load is not possible. The
application (not ours) just works this way.
I hope one of the options will work, cause else I must say DB2 is not
build for high transaction volumes we are doing and that would be very
sad.
I read about the benefits from type-2 indexes, but there seems to be a
big drawback because it reduce the efficiency of the index big time in
our situation.


DB2 has done very well in benchmarks with high transaction volumes, so it is
built for such workloads. In fact, DB2 holds the record for the highest tpmC
in the TPC-C benchmark.
http://www.tpc.org/tpcc/results/tpcc_perf_results.asp
Jan 2 '06 #4
Yes DB2 is wel tuned for TPC-C...
But DB2 has like other databases some drawbacks.
Why does DB2 do logical deletes on indexes anyway? That's really
obsolete technology.
Enabling online index defragmentation using minpctused must have some
impact, otherwise it would be default or could someone shed a light why
you don't want that as default.
But why logical deletes?

And there other issues with DB2 like clustering and overflow rows which
all need reorgs because they reduce the performance overtime.
You can do online reorgs, but if your running high volumes transactions
24x7 it's a loose - loose situation:
- reduced perfomance because tables /indexes need reorgs
- reduced performance because your running reorgs constantly

Automation is nice, but maybe they can try and resolve the cause of the
high maintance DB2 requires because those high volumes we are running
the online reorgs just cannot keep up.

Well DB2 is old so it must be a feature. I just hope that someday they
announce these reorg features are no more.

Jan 3 '06 #5
be**************@gmail.com wrote:
Thanks for the tip and suggestions.
I'll try the high percent free value, but the load is not possible. The
application (not ours) just works this way.
I hope one of the options will work, cause else I must say DB2 is not
build for high transaction volumes we are doing and that would be very
sad.
I read about the benefits from type-2 indexes, but there seems to be a
big drawback because it reduce the efficiency of the index big time in
our situation.

Would you mind telling us more about the load.
E.g. do the INSERTs all happen at the end of the index (identity column)?
I haven't heard of issues with TYPE 2 indexes before. Maybe opening a
PMR would be in order to get to the bottom of this....

Cheers
Serge
--
Serge Rielau
DB2 Solutions Development
DB2 UDB for Linux, Unix, Windows
IBM Toronto Lab
Jan 3 '06 #6
Hi Serge,

Well I think we have more than one table having problems with pseudo
keys.
Because of the high transaction volume a table lock is never possible,
so the index leaf pages are never cleaned of pseudo empty pages.
We have one table with one index on a sequence number.
One proces is filling the table the other is reading it bottom up and
deleting the processed rows.
When you do a min(sequence) query using UR it takes > 5 seconds before
we get an answer. After a index reorg it is quick again, wel for a
minute or so.

They way I look at it, it only works if a table lock can be achieved
and that does not seem to be the case. Same thing on other tables.

Jan 3 '06 #7
I am curious ... you are linking this performance to Type-II indexes ... did
you run similar tests with the original Type-I indexes and if so what was
the performance at that time?

The whole point of Type-II indexes and pseudo-deleted keys is that only
those transactions that need to be blocked, are. So transaction rates should
be going up with Type-II as compared to Type-I... hence my question as to
what did you see with Type-I indexes? Do you have any comparative
performance numbers?

The last time I checked (and this "may" have changed), cleanup of pseudo
deleted keys and deletion of pseudo empty pages will be done on the fly by
other transactions after a deleting transaction has completed. Of course,
this can always be manually triggered as you have alluded to, but don't
forget that you now have "online" reorg of indexes. It does not have to be
an offline process.

Bob

§<be**************@gmail.com> wrote in message
news:11**********************@g44g2000cwa.googlegr oups.com...
Hi Serge,

Well I think we have more than one table having problems with pseudo
keys.
Because of the high transaction volume a table lock is never possible,
so the index leaf pages are never cleaned of pseudo empty pages.
We have one table with one index on a sequence number.
One proces is filling the table the other is reading it bottom up and
deleting the processed rows.
When you do a min(sequence) query using UR it takes > 5 seconds before
we get an answer. After a index reorg it is quick again, wel for a
minute or so.

They way I look at it, it only works if a table lock can be achieved
and that does not seem to be the case. Same thing on other tables.

Jan 3 '06 #8
Hi Bob,

We never used type-1 indexes. We started with version 8.

DB2 IC says under tuning - online index defragmentation:
"For type-2 indexes, keys are removed from a page during key deletion
only when there is an X lock on the table. During such an operation,
online index defragmentation will be effective. However, if there is
not an X lock on the table during key deletion, keys are marked deleted
but are not physically removed from the index page. As a result, no
defragmentation is attempted."

But now I've read it again I'm confused if they mean when this is when
you use MINPCTUSED.

Well I'm open to suggestion why a REORG INDEXES CLEANUP ONLY PAGES will
actually speed things up.
I'm doing this while the applications is running (using ALLOW WRITE
ACCESS).

Jan 3 '06 #9
be**************@gmail.com wrote:
Hi Serge,

Well I think we have more than one table having problems with pseudo
keys.
Because of the high transaction volume a table lock is never possible,
so the index leaf pages are never cleaned of pseudo empty pages.
We have one table with one index on a sequence number.
One proces is filling the table the other is reading it bottom up and
deleting the processed rows.
When you do a min(sequence) query using UR it takes > 5 seconds before
we get an answer. After a index reorg it is quick again, wel for a
minute or so.

They way I look at it, it only works if a table lock can be achieved
and that does not seem to be the case. Same thing on other tables.

So what you do is queue processing. This, btw, is exactly what TPC-C
does and of course we use type-2 indexes there.
I'll send you some slides as a PDF. They may give you some ideas.

Cheers
Serge
--
Serge Rielau
DB2 Solutions Development
DB2 UDB for Linux, Unix, Windows
IBM Toronto Lab
Jan 3 '06 #10
Serge Rielau wrote:
I'll send you some slides as a PDF. They may give you some ideas.

Cheers
Serge

Hmm... an invalid gmail address? Well.. ping me if you want slides...

Cheers
Serge
--
Serge Rielau
DB2 Solutions Development
DB2 UDB for Linux, Unix, Windows
IBM Toronto Lab
Jan 4 '06 #11
Sorry, but google does not let me use a gmail account for some reason.
But I'm interested in the slides, I'll email you from my business
account.

And indeed it is used as a queue.
Maybe you can explain the following snapshot from the dynamic SQL:
It's a snapshot taken with a 120 seconds interval (after reset):

Number of executions = 13
Number of compilations = 0
Worst preparation time (ms) = 4
Best preparation time (ms) = 1
Internal rows deleted = 0
Internal rows inserted = 0
Rows read = 0
Internal rows updated = 0
Rows written = 0
Statement sorts = 0
Statement sort overflows = 0
Total sort time = 0
Buffer pool data logical reads = 0
Buffer pool data physical reads = 0
Buffer pool temporary data logical reads = 0
Buffer pool temporary data physical reads = 0
Buffer pool index logical reads = 192060
Buffer pool index physical reads = 192041
Buffer pool temporary index logical reads = 0
Buffer pool temporary index physical reads = 0
Total execution time (sec.ms) = 58.367505
Total user cpu time (sec.ms) = 5.380000
Total system cpu time (sec.ms) = 9.150000
Statement text = (SELECT MIN(EVENT_SEQ) + ? FROM
FMC.HS_AUDIT_TRAIL)

The table looks likes this and has > 20 miljoen rows.

------------------------------------------------
-- DDL Statements for table "FMC "."HS_AUDIT_TRAIL"
------------------------------------------------

CREATE TABLE "FMC "."HS_AUDIT_TRAIL" (
"EVENT_SEQ" DECIMAL(16,0) NOT NULL WITH DEFAULT 0 ,
"CREATED" TIMESTAMP ,
"EVENT" INTEGER ,
"TEMPL_VALID_FROM" TIMESTAMP ,
"PROCESS_NAME" VARCHAR(63) ,
"PROCESS_ID" VARCHAR(64) ,
"TOP_LVL_PROC_NAME" VARCHAR(63) ,
"TOP_LVL_PROC_ID" VARCHAR(64) ,
"PARENT_PROC_NAME" VARCHAR(63) ,
"PARENT_PROC_ID" VARCHAR(64) ,
"PROC_TEMPL_NAME" VARCHAR(32) ,
"BLOCK_NAMES" VARCHAR(254) ,
"USER_NAME" VARCHAR(32) ,
"SECOND_USER_NAME" VARCHAR(32) ,
"ACTIVITY_NAME" VARCHAR(32) ,
"ACTIVITY_TYPE" INTEGER ,
"ACTIVITY_STATE" INTEGER ,
"COMMAND_PARAMETERS" VARCHAR(1024) ,
"PROGRAM_NAME" VARCHAR(32) ,
"ACTIVITY_RC" INTEGER ,
"ASSOCIATED_OBJECT" VARCHAR(64) ,
"OBJECT_DESCRIPTION" VARCHAR(254) ,
"SECOND_ACT_NAME" VARCHAR(32) ,
"EXTERNAL_CONTEXT" VARCHAR(254) )
IN "HFX" ;
ALTER TABLE "FMC "."HS_AUDIT_TRAIL" VOLATILE CARDINALITY;

-- DDL Statements for indexes on Table "FMC "."HS_AUDIT_TRAIL"

CREATE INDEX "FMC "."HS_AT_SEQ_INDEX" ON "FMC
"."HS_AUDIT_TRAIL"
("EVENT_SEQ" ASC);
There are no trigger on the table.
After doing a full reorg from the index only the snapshot looked like
this:
Number of executions = 55
Number of compilations = 0
Worst preparation time (ms) = 12
Best preparation time (ms) = 0
Internal rows deleted = 0
Internal rows inserted = 0
Rows read = 0
Internal rows updated = 0
Rows written = 0
Statement sorts = 0
Statement sort overflows = 0
Total sort time = 0
Buffer pool data logical reads = 0
Buffer pool data physical reads = 0
Buffer pool temporary data logical reads = 0
Buffer pool temporary data physical reads = 0
Buffer pool index logical reads = 9130
Buffer pool index physical reads = 0
Buffer pool temporary index logical reads = 0
Buffer pool temporary index physical reads = 0
Total execution time (sec.ms) = 0.120709
Total user cpu time (sec.ms) = 0.000000
Total system cpu time (sec.ms) = 0.000000
Statement text = (SELECT MIN(EVENT_SEQ) + ? FROM
FMC.HS_AUDIT_TRAIL)

Even after the reorg each query takes an average of 166 i/o's. Must be
a big index tree.
Don't know how I can find out exactly how big the tree is in size and
levels.

Jan 5 '06 #12
The number of levels is contained in the syscat.indexes tables as
documented in Appendix D fo the SQL Reference Vol 1. This value is
updated after you run runstats command on the index.

Jan 5 '06 #13

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

3
by: dgaucher | last post by:
Hi, I want to consume a Web Service that returns a choice, but my C++ client always receives the same returned type. On the other hand, when I am using a Java client, it is working fine (of...
6
by: S.Tobias | last post by:
I'm trying to understand how structure type completion works. # A structure or union type of unknown # content (as described in 6.7.2.3) is an incomplete type. It # is ...
0
by: Chris Fink | last post by:
When I am consuming a webservice, an object has an undefined value (inq3Type.Call3Data). I do not completely understand why this is happening and apologize for the vague question. My assumption...
1
by: Rob Griffiths | last post by:
Can anyone explain to me the difference between an element type and a component type? In the java literature, arrays are said to have component types, whereas collections from the Collections...
669
by: Xah Lee | last post by:
in March, i posted a essay “What is Expressiveness in a Computer Language”, archived at: http://xahlee.org/perl-python/what_is_expresiveness.html I was informed then that there is a academic...
3
by: john | last post by:
Hi to All To demonstrate: public class MyBaseGenericClass<T> { } public class MyGenericClass1<T: MyBaseGenericClass<T> {
7
by: Sky | last post by:
I have been looking for a more powerful version of GetType(string) that will find the Type no matter what, and will work even if only supplied "{TypeName}", not the full "{TypeName},{AssemblyName}"...
9
by: weirdwoolly | last post by:
Hopefully someone will be able to help. I have written a stored procedure in C++ called from a Java test harness to validate the graphic data types in C++ and their use. I have declared the...
5
by: JH | last post by:
Hi I found that a type/class are both a subclass and a instance of base type "object". It conflicts to my understanding that: 1.) a type/class object is created from class statement 2.) a...
3
by: amanjsingh | last post by:
Hi, I am trying to implement Java Web Service using Apache Axis2 and Eclipse as a tool. I have created the basic code and deployed the service using various eclipse plugin but when I try to invoke...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...
0
agi2029
by: agi2029 | last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.