标签:des style os io ar strong for div cti
关于CACHE BUFFERS CHAINS描述
| CACHE BUFFERS CHAINS latch is acquired when searching
fordata blocks cached
inthe buffer cache.
Since the Buffer cache is implemented as a
sumof chains of blocks, each of those chains is protected
by a child of this latch when needs to be scanned. Contention
inthis latch can be caused by very heavy
access to a single block. This can require the application to be reviewed. | 
产生CACHE BUFFERS CHAINS原因
| The main cause of the cache buffers chains latch contention is usually a hot block issue.
This happens when multiple sessions repeatedly access one or
moreblocks that are protected
by the same child cache buffers chains latch. | 
CACHE BUFFERS CHAINS 处理方法
1) Examine the application to see if the execution of certain DML and SELECT statements can be reorganized to eliminate contention on the object.
| 处理方法如下:--通过报告确定latch: cache buffers chains 等待Top 5 Timed Events                                      Avg    %Total~~~~~~~~~~~~~~~~~~                                      wait   CallEvent                          Waits        Time (s)    (ms)   Time   Wait Class------------------------------ ------------ ----------- ------ ------ ----------latch: cache buffers chains          74,642      35,421    475    6.1 ConcurrencCPU
time11,422           2.0log
filesync34,890       1,748     50    0.3 Commitlatch
free
2,279         774    340    0.1 Otherdb
fileparallel write               18,818         768     41    0.1 System I/O---------------------------------------------------------------找出逻辑读高sqlSQL ordered by Gets         DB/Inst:  Snaps: 1-2-> Resources reported
forPL/SQLcode includes the resources used by all SQLstatements called by the code.-> Total Buffer Gets:   265,126,882-> Captured SQL account
for99.8% of Total                            Gets                CPU      ElapsedBuffer Gets    Executions   per Exec     %Total Time (s) Time (s)  SQL Id-------------- ------------ ------------ ------ -------- --------- -------------   256,763,367       19,052     13,477.0   96.8
######## ######### a9nchgksux6x2Module: JDBC Thin ClientSELECT * FROM SALES ....     1,974,516      987,056          2.0    0.7    80.31    110.94 ct6xwvwg3w0bvSELECT COUNT(*) FROM ORDERS ....--逻辑读大对象Segments by Logical Reads          
-> Total Logical Reads:     265,126,882-> Captured Segments account
for98.5% of Total           Tablespace                      Subobject  Obj.       LogicalOwner         Name    Object Name            Name     Type         Reads  %Total---------- ---------- -------------------- ---------- ----- ------------ -------DMSUSER    USERS      SALES                           TABLE  212,206,208   80.04DMSUSER    USERS      SALES_PK                        INDEX   44,369,264   16.74DMSUSER    USERS      SYS_C0012345                    INDEX    1,982,592     .75DMSUSER    USERS      ORDERS_PK                       INDEX      842,304     .32DMSUSER    USERS      INVOICES                        TABLE      147,488     .06          -------------------------------------------------------------处理思路:1.Look
forSQL that accesses the blocks
inquestion and determine
ifthe repeated reads are necessary.
  This may be within a single session or across multiple sessions.2.Check
forsuboptimal SQL (this is the most common cause of the events) 
 lookat the execution plan forthe SQL being run and try to reduce the  gets per executions
whichwill minimize the number of blocks being accessed
 and therefore reduce the chances of multiple sessions contending
forthe same block. | 
Note:1342917.1 Troubleshooting ‘latch: cache buffers chains’ Wait Contention
2) Decrease the buffer cache -although this may only help in a small amount of cases.
3) DBWR throughput may have a factor in this as well.If using multiple DBWR’s then increase the number of DBWR’s.
4) Increase the PCTFREE for the table storage parameters via ALTER TABLE or rebuild. This will result in less rows per block.
| 找出热点对象First determine
whichlatch id(ADDR) are interesting by examining the number of
sleeps
forthis latch. The higher the
sleepcount, the
moreinteresting the
latch
id(ADDR) is:SQL>
selectCHILD#  "cCHILD"     ,      ADDR   
"sADDR"     ,      GETS   
"sGETS"     ,      MISSES 
"sMISSES"     ,      SLEEPS 
"sSLEEPS"     from
v$latch_children
     where name =
‘cache buffers chains‘     order by 5, 1, 2, 3;Run the above query a few
timesto to establish the
id(ADDR) that has the most
consistent amount of sleeps. Once the
id(ADDR) with the highest
sleepcount is foundthenthis latch address can be used to get moredetails about the blockscurrently
inthe buffer cache protected by this latch.
The query below should be run just after determining the ADDR with
the highest
sleepcount.SQL> column segment_name
formata35     select/*+ RULE */       e.owner ||‘.‘|| e.segment_name  segment_name,       e.extent_id  extent#,       x.dbablk - e.block_id + 1  block#,       x.tch,       l.child#     from       sys.v$latch_children  l,       sys.x$bh  x,       sys.dba_extents  e     where       x.hladdr  =
‘&ADDR‘and       e.file_id = x.file# and       x.hladdr = l.addr and       x.dbablk between e.block_id and e.block_id + e.blocks -1     order by x.tch desc ;Example of the output :SEGMENT_NAME                     EXTENT#      BLOCK#       TCH    CHILD#-------------------------------- ------------ ------------ ------ ----------SCOTT.EMP_PK                       5            474          17     7,668SCOTT.EMP                          1            449           2     7,668Depending on the TCH column (The number of
timesthe block is hit by a SQL
statement), you can identify a hot block. The higher the value of the TCH column,the
morefrequent the block is accessed by SQL statements. | 
5) Consider implementing reverse key indexes (if range scans aren’t commonly used against the segment)
WAIT EVENT: latch: cache buffers chains
标签:des style os io ar strong for div cti
原文地址:http://blog.csdn.net/ora_unix/article/details/39177887