Oracle FAQ Your Portal to the Oracle Knowledge Grid
HOME | ASK QUESTION | ADD INFO | SEARCH | E-MAIL US
 

Home -> Community -> Mailing Lists -> Oracle-L -> Re: Logical Standby Issues (cont.)

Re: Logical Standby Issues (cont.)

From: Mark Strickland <strickland.mark_at_gmail.com>
Date: Thu, 10 Aug 2006 14:55:19 -0700
Message-ID: <90ad14210608101455r313caae9k3d0b860552e2b598@mail.gmail.com>


I'm using SGA_TARGET, so my other SGA memory parameters aren't set. SGA_TARGET=1500M. That's small but it's a test database. I did test with a larger SGA (3500M) and with the logical standby parameter MAX_SGA set to 2000. No difference. I am neither CPU nor IO bound. I ran OSWatcher during the tests. I can't easily set up a Solaris 10 OS environment at the moment. The Apply process uses a single update SQL statement with bind variables that it executes 1,000,000 times. It does use the table's primary key index. When I tested 1,000,000 unique update statements (i.e. with literals, not bind variables) running directly in the standby from a SQL script, it took 50 minutes, even with all that hard parsing and not-large SGA. Here's the update statement that is executed by SQL Apply:

update /*+ streams restrict_all_ref_cons */ "MILA"."RATEMARGINADD" p set "ANEWCOLUMN"=decode(:1,'N',"ANEWCOLUMN",:2),

"BACKUP_MARGIN"=decode(:3,'N',"BACKUP_MARGIN",:4),
"DATELASTMODIFIED"=decode(:5,'N',"DATELASTMODIFIED",:6),
"DATERECORDADDED"=decode(:7,'N',"DATERECORDADDED",:8),
"MARGIN"=decode(:9,'N',"MARGIN",:10),
"NAME"=decode(:11,'N',"NAME",:12),
"OID"=decode(:13,'N',"OID",:14),
"OIDMORTGAGE"=decode(:15,'N',"OIDMORTGAGE",:16),
"ORDINAL"=decode(:17,'N',"ORDINAL",:18),
"RATE"=decode(:19,'N',"RATE",:20)

where (:21='N' or
(decode(:22,'N','Y',decode(:23,"ANEWCOLUMN",'Y'))='Y' and
decode(:24,'N','Y',decode(:25,"BACKUP_MARGIN",'Y'))='Y' and
decode(:26,'N','Y',decode(:27,"DATELASTMODIFIED",'Y'))='Y' and
decode(:28,'N','Y',decode(:29,"DATERECORDADDED",'Y'))='Y' and
decode(:30,'N','Y',decode(:31,"MARGIN",'Y'))='Y' and
decode(:32,'N','Y',decode(:33,"NAME",'Y'))='Y' and 1=1 and
decode(:34,'N','Y',decode(:35,"OIDMORTGAGE",'Y'))='Y' and
decode(:36,'N','Y',decode(:37,"ORDINAL",'Y'))='Y' and
decode(:38,'N','Y',decode(:39,"RATE",'Y'))='Y')) and(:40="OID") and
rownum < 2;

Mark

On 8/10/06, Rich Amick <rAmick_at_dotster.com> wrote:
> What is the size of your streams pool?
>
> In your snapshots, what are the values for CPU time, User IO time and Sys IO
> time for the apply reader and the logminer reader?
> Ie. are you CPU or IO bound?
>
> Can you set up a Solaris 10 OS env?
> If so, maybe dtrace on the apply process would help...
>
> Also, the apply process should just use straight SQL as noted by Carel-Jan
> Engel. A tkprof'd level 12 10046 trace of the apply process during the test
> might also prove useful.
>
> -----Original Message-----
> From: Mark Strickland [mailto:strickland.mark_at_gmail.com]
> Sent: Thursday, August 10, 2006 1:55 PM
> To: Rich Amick
> Cc: oracle-l_at_freelists.org
> Subject: Re: Logical Standby Issues (cont.)
>
> Oh yeah, I've taken AWR snapshots and run the logical standby
> diagnostics script provided on Metalink. I've set logical standby
> parameters as recommended by Oracle Support. I've set various events
> and levels of tracing. Yes, it is the Applier process that is
> consuming the CPU. In 10gR1, there is latch contention while Log
> Miner is scraping DMLs out of the archived logs (Log Miner Work Area
> latch) but the latch contention goes away once Log Mining finishes.
> Log Mining takes about half of the total elapsed time of the test.
> However, SQL Apply does not suddenly speed up. It continues its
> linear trajectory toward more slowness. In my 10gR2 tests, the latch
> contention doesn't exist but the test still takes close to the same
> amount of time as in 10gR1. Log Mining takes about 34 minutes which
> is much faster than in 10gR1. I've graphed the amount of time between
> log switches in the standby. It gets longer and longer and the graph
> is linear pointing Northeast. In the 10gR1 tests, each redo log takes
> about 28 seconds longer on average to fill than the last one for
> roughly the same number of SCNs. In the 10gR2 tests, each redo log
> takes about 10 seconds longer to fill than the last one but there are
> more log switches than in 10gR1. Don't know why and haven't looked
> into it. At any rate 10gR2 is a little faster than 10gR1 but not by
> much. From the AWR reports I can easily see from the number of
> executions of the update statement for each time period covered by the
> AWR snapshot that SQL Apply is slowing down.
>
> Thanks for responding.
>
> Mark
>
>

--
http://www.freelists.org/webpage/oracle-l
Received on Thu Aug 10 2006 - 16:55:19 CDT

Original text of this message

HOME | ASK QUESTION | ADD INFO | SEARCH | E-MAIL US