x$ kernel service & cache table tips

x$ kernel service & cache table tips


Exploring Oracle 11g Database Internals with x$ Tables

In order to query the x$ tables, one must have SYS level privilegeswithin the Oracle 11g database environment. Due to the hundreds of x$ tables in each major release of Oracle, it would take a huge amount of material to cover each and every one in great detail. Therefore, this chapter will provide a listing of the key x$ tables centered around the kernel layers with some example scripts to explain how to access the Oracle 11g database kernel internal information. The following family listing of x$ tables allows one to view the status for kernel services (KS) within Oracle 11g.

X$KS– Kernel Services

x$ksmfs

Memory fixed SGA

x$ksmfsv

Memory fixed SGA vectors

x$ksmjs

Java Pool memory

x$ksmlru

Memory LRU (least recently used)

x$ksmls

Large pool memory

x$ksmmem

Memory

x$ksmpp

Memory Process Pool

x$ksmsd

Memory SGA definitions

x$ksmsp

Shared pool Memory

x$ksmspr

Shared pool reserved memory

x$ksmss

Shared pool summary

x$ksmup

User pool memory

x$ksqst

Enqueue status

x$ksulop

User long operation

x$ksulv

User locale value

x$ksupr

User process

It is demonstrated here how to understand shared pool memory by performing a describe on the x$ksmsp table:

SQL> describe x$ksmsp

 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------
 ADDR                                               RAW(4)
 INDX                                               NUMBER
 INST_ID                                            NUMBER
 KSMCHIDX                                           NUMBER
 KSMCHDUR                                           NUMBER
 KSMCHCOM                                           VARCHAR2(16)
 KSMCHPTR                                           RAW(4)
 KSMCHSIZ                                           NUMBER
 KSMCHCLS                                           VARCHAR2(8)
 KSMCHTYP                                           NUMBER
 KSMCHPAR                                           RAW(4)

The following example query against the x$ksmsp table allows one to understand how shared pool memory is currently being used by the Oracle 11g database.

SQL> select ksmchcom AComment,
  2  ksmchcls Status,
  3  sum(ksmchsiz) Bytes
  4  from x$ksmsp
  5  group by ksmchcom, ksmchcls;

ACOMMENT         STATUS        BYTES
---------------- -------- ----------
sql area         recr        3354624
PL/SQL DIANA     freeabl     8753152
trigger defini   recr          94404
joxlod exec hp   recr         269792
partitioning d   recr          18052
sql area:KOKA    recr          40960
policy hash tab  freeabl         164
Label Cache Hea  freeabl         104
qtree_kwqspqctx  freeabl          40
dbgefgHtAddSK-1  freeabl      450996
Session Page     freeabl        6776

Now review an example of how to understand x$ tables by querying against one of the key x$kc tables for the Kernel Cache (KC) layer with Oracle 11g.

X$KC – Kernel Cache

x$kcbfwai

Block file wait

x$kcbwait

Block wait

x$kcccp

Checkpoint progress controlfile

x$kcfio

File I/O  

x$kclfh

Lock file header

x$kclfi

Lock file index

x$kcluh

Lock undo header

x$kclui

Lock undo index

For this case study of the Kernel Cache (KC) family of x$ tables, give a code example with the x$kcbfwaittable to examine buffer busy wait issues.

The following script shows the datafiles that have data blocks wait conditions present waited on within the test Oracle 11g database.

SQL> select count, file#, name
  2  from x$kcbfwait, v$datafile
  3  where indx+1=file#
  4  order by count;

     COUNT      FILE#   NAME
------------------------------------------------
         0          3   C:\WIN11G1\ORADATA\WIN11G\UNDOTBS01.DBF
 
         0          2   C:\WIN11G1\ORADATA\WIN11G\SYSAUX01.DBF
 
         0          5   C:\WIN11G1\ORADATA\WIN11G\EXAMPLE01.DBF
 
 
     COUNT      FILE#   NAME
------------------------------------------------
         0          4   C:\WIN11G1\ORADATA\WIN11G\USERS01.DBF
 
        33          1   C:\WIN11G1\ORADATA\WIN11G\SYSTEM01.DBF
 

SQL>

Next to be used is an example to understand the kernel query layer of the 11g database kernel from the x$kq family.

X$KQ – Kernel Query

x$kqfco

Fixed table columns

x$kqfdt

Fixed table

x$kqfp

Fixed procedure

x$kqfsz

Fixed size

x$kqfta

Fixed table

x$kqfvi

Fixed view

x$kqfvt 

Fixed view table

Now one can examine the 11g database internal structures for fixed tables and views by usage of the x$kqkernel query tables. For instance, issue a query against the x$kqfvitable which will provide the complete listing for all v$ and gv$ views based on the x$ tables for Oracle 11g.

SQL> select kqfvinam from x$kqfvi;

KQFVINAM
------------------------------                                                 
GV$WAITSTAT                                                                    
V$WAITSTAT                                 
                                    
GV$BH                                                                          
V$BH                                                                           
GV$GC_ELEMENT                                           
                       
V$GC_ELEMENT                                                                   
GV$CR_BLOCK_SERVER                                                             
V$CR_BLOCK_SERVER                                                    
          
GV$CURRENT_BLOCK_SERVER                                                        
V$CURRENT_BLOCK_SERVER                                                         
GV$ENCRYPTED_TABLESPACES                                                       
V$ENCRYPTED_TABLESPACES                                                        
GV$GC_ELEMENTS_WITH_COLLISIONS                                                 
V$GC_ELEMENTS_WITH_COLLISIONS                                                  
GV$FILE_CACHE_TRANSFER                                                         
V$FILE_CACHE_TRANSFER                                                          
GV$TEMP_CACHE_TRANSFER                                                         
V$TEMP_CACHE_TRANSFER      
                                                    
GV$CLASS_CACHE_TRANSFER                                                        
V$CLASS_CACHE_TRANSFER                                                         
GV$INSTANCE_CACHE_TRANSFER              
                                       
V$INSTANCE_CACHE_TRANSFER                                                      
GV$LOCK_ELEMENT                                                                
V$LOCK_ELEMENT                                       
                          
GV$BSP                                                                         
V$BSP                                                                          
GV$LOCKS_WITH_COLLISIONS                                          
             
V$LOCKS_WITH_COLLISIONS                                                        
GV$FILE_PING                                                                   
V$FILE_PING                                                                    
GV$TEMP_PING                                                                   
V$TEMP_PING                                                                    
GV$CLASS_PING                 
                                                 

The listing from x$kqfvi is now available, so proceed to examine other Oracle 11g database structures within the database kernel by accessing the x$kq layer of the generic kernel database structures. The following table lists the most frequently used x$kq kernel generic x$ tables.

X$KG – Kernel Generic

x$kghlu

 Heap LRU (Least Recently Used)

x$kgllk

 Library cache lock

x$kglob

 Library cache object

x$kglpn

 Library cache pin

x$kglst

 Library cache status

If a DBA is experiencing performance degradation issues due to library cache issues, then query the x$kgllktable to investigate further.

C:\>sqlplus "/as sysdba"
 
SQL*Plus: Release 11.1.0.6.0 - Production on Thu May 14 16:43:01 2009
 
Copyright (c) 1982, 2007, Oracle.  All rights reserved.
 
Connected to:
Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing
options
 
SQL> select
  2    kglnaobj, kgllkreq
  3  from
  4    x$kgllk x join v$session s on
  5      s.saddr = x.kgllkses;

KGLNAOBJ                                                       KGLLKREQ
------------------------------------------------------------ ----------
table_4_9_1322_0_0_0                                                  0
table_4_9_1322_0_0_0                                                  0
STANDARD                                                              0
DBMS_PRVT_TRACE                                                       0
table_1_ff_20b_0_0_0                                                  0
table_1_ff_20b_0_0_0                                                  0
select 1 from sys.aq$_subscriber_table where rownum < 2 and           0
select 1 from sys.aq$_subscriber_table where rownum < 2 and           0
select decode(bitand(a.flags, 16384), 0, a.next_run_date,             0
select decode(bitand(a.flags, 16384), 0, a.next_run_date,             0
select con#,obj#,rcon#,enabled,nvl(defer,0) from cdef$ where          0
 
select con#,obj#,rcon#,enabled,nvl(defer,0) from cdef$ where          0
insert into smon_scn_time (thread, time_mp, time_dp, scn, sc          0
select obj#,type#,ctime,mtime,stime,status,dataobj#,flags,oi          0
select obj#,type#,ctime,mtime,stime,status,dataobj#,flags,oi          0
select obj#,type#,ctime,mtime,stime,status,dataobj#,flags,oi          0
select obj#,type#,ctime,mtime,stime,status,dataobj#,flags,oi          0
table_1_ff_207_0_0_0                                                  0
table_1_ff_207_0_0_0                                                  0
select con#,type#,condlength,intcols,robj#,rcon#,match#,refa          0
select con#,type#,condlength,intcols,robj#,rcon#,match#,refa          0
AQ$_ALERT_QT_E                                                        0
 
select name,intcol#,segcol#,type#,length,nvl(precision#,0),d          0
select name,intcol#,segcol#,type#,length,nvl(precision#,0),d          0
select name,intcol#,segcol#,type#,length,nvl(precision#,0),d          0
select name,intcol#,segcol#,type#,length,nvl(precision#,0),d          0
DELETE FROM RECENT_RESOURCE_INCARNATIONS$ WHERE RESOURCE_TYP          0
DELETE FROM RECENT_RESOURCE_INCARNATIONS$ WHERE RESOURCE_TYP          0
select decode(bitand(a.flags, 16384), 0, a.next_run_date,             0
select decode(bitand(a.flags, 16384), 0, a.next_run_date,             0
DBMS_HA_ALERTS_PRVT                                                   0
BEGIN  dbms_ha_alerts_prvt.clear_instance_resources(   :dbdo          0
BEGIN  dbms_ha_alerts_prvt.clear_instance_resources(   :dbdo          0 

select   kglnaobj, kgllkreq from   x$kgllk x join v$session           0
select   kglnaobj, kgllkreq from   x$kgllk x join v$session           0
select  tab.rowid, tab.msgid, tab.corrid, tab.priority, tab.          0

KGLNAOBJ                                                       KGLLKREQ
------------------------------------------------------------ ----------
select  tab.rowid, tab.msgid, tab.corrid, tab.priority, tab.          0
select subscriber_id, name, address, protocol, subscriber_ty          0
select subscriber_id, name, address, protocol, subscriber_ty          0
STANDARD                                                              0
table_1_ff_213_0_0_0                                                  0
table_1_ff_213_0_0_0                                                  0
ALERT_QUE_R                                                           0
table_1_ff_20f_0_0_0                                                  0 

table_1_ff_20f_0_0_0                                                  0
select a.next_start_date, a.objid, a.w_open from  (select b.          0
select a.next_start_date, a.objid, a.w_open from  (select b.          0
PLITBLM                                                               0
ALERT_QUE                                                             0
select /*+ FIRST_ROWS(1) */ x.C1, x.C2, x.C3 from  (select a          0
select /*+ FIRST_ROWS(1) */ x.C1, x.C2, x.C3 from  (select a          0
select OBJOID,  CLSOID, RUNTIME, PRI, JOBTYPE,  SCHLIM,  WT,          0
select OBJOID,  CLSOID, RUNTIME, PRI, JOBTYPE,  SCHLIM,  WT,          0
insert into "SYS"."ALERT_QT"  (q_name, msgid, corrid, priori          0
insert into "SYS"."ALERT_QT"  (q_name, msgid, corrid, priori          0 

DBMS_HA_ALERTS_PRVT                                                   0
SELECT INSTANCE_NAME, HOST_NAME, NVL(GVI_STARTUP_TIME, SYSTI          0
SELECT INSTANCE_NAME, HOST_NAME, NVL(GVI_STARTUP_TIME, SYSTI          0
table_1_ff_203_0_0_0                                                  0
table_1_ff_203_0_0_0                                                  0
table_1_ff_203_0_0_0                                                  0
table_1_ff_203_0_0_0                                                  0
select intcol#,nvl(pos#,0),col#,nvl(spare1,0) from ccol$ whe          0
select intcol#,nvl(pos#,0),col#,nvl(spare1,0) from ccol$ whe          0
select CONNECTION_POOL_NAME, STATUS, MINSIZE, MAXSIZE,                0
select CONNECTION_POOL_NAME, STATUS, MINSIZE, MAXSIZE,                0 

select i.obj#,i.ts#,i.file#,i.block#,i.intcols,i.type#,i.fla          0
select i.obj#,i.ts#,i.file#,i.block#,i.intcols,i.type#,i.fla          0
select i.obj#,i.ts#,i.file#,i.block#,i.intcols,i.type#,i.fla          0
select i.obj#,i.ts#,i.file#,i.block#,i.intcols,i.type#,i.fla          0
select max(RETENTION) from SYS_FBA_FA                                 0
select max(RETENTION) from SYS_FBA_FA                                 0
DATABASE                                                              0
select t.ts#,t.file#,t.block#,nvl(t.bobj#,0),nvl(t.tab#,0),t          0
select t.ts#,t.file#,t.block#,nvl(t.bobj#,0),nvl(t.tab#,0),t          0
select t.ts#,t.file#,t.block#,nvl(t.bobj#,0),nvl(t.tab#,0),t          0
select t.ts#,t.file#,t.block#,nvl(t.bobj#,0),nvl(t.tab#,0),t          0 

update sys.mon_mods$ set inserts = inserts + :ins, updates =          0
ALTER SESSION SET NLS_LANGUAGE= 'AMERICAN' NLS_TERRITORY= 'A          0
select value, flags, modified_inst, additional_info,                  0
select value, flags, modified_inst, additional_info,                  0
SELECT OBJOID, CLSOID,    DECODE(BITAND(FLAGS, 16384), 0, RU          0
SELECT OBJOID, CLSOID,    DECODE(BITAND(FLAGS, 16384), 0, RU          0
select f.file#, f.block#, f.ts#, f.length from fet$ f, ts$ t          0
DBMS_PRVT_TRACE                                                       0
COMMIT                                                                0
select 1 from obj$ where name='DBA_QUEUE_SCHEDULES'                   0
select 1 from obj$ where name='DBA_QUEUE_SCHEDULES'                   0
88 rows selected.
SQL>

The advantage of using the above x$ table query against the x$kgllk table is that more information is provided by using this x$ table than the v$lockquery. Recalling from earlier on, it was mentioned that all of the v$ dynamic performance views are based upon x$ tables. In the above query code listing, the  x$kgllk table lists all held and requested library object locks for all sessions within Oracle 11g.

Now decipher some of the columns in the x$kgllk table from the query that was just ran against the Oracle 11g database. In the x$kgllk table, the column kglnaobj displays the name of the object in terms of the first 80 characters of the object name. If one examines the kgllkreqcolumn, it can be determined that a value of zero indicates that a lock is being held, whereas a value greater than zero for the kgllkreq column indicates that a lock has been requested within the Oracle database. As can be seen, using x$ tables will expand the realm of performance and database analysis for complex Oracle issues. Now examine the x$ tables for the kernel security (KZ) layer within Oracle 11g.

X$KZ – Kernel Security (KZ) Layer

 x$kzspr

Enabled Privileges

 x$kzsro

Enabled Roles

 x$kzsrt

Remote Password File Table Entries

As these x$ tables are undocumented, next to be reviewed is an example of the security kernel layer for Oracle 11g roles and privileges by querying against the x$kzspr and x$kzsrttables. First, obtain the column definitions for the three security x$ tables.

SQL> desc x$kzspr

 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------
 ADDR                                               RAW(4)
 INDX                                               NUMBER
 INST_ID                                            NUMBER
 KZSPRPRV                                           NUMBER

SQL> desc x$kzsro

Name                                      Null?    Type
----------------------------------------- -------- ----------------
 ADDR                                               RAW(4)
 INDX                                               NUMBER
 INST_ID                                            NUMBER
 KZSROROL                                           NUMBER

SQL> desc x$kzsrt

 

Name                                      Null?    Type
----------------------------------------- -------- -----------------
 ADDR                                               RAW(4)
 INDX                                               NUMBER
 INST_ID                                            NUMBER
 USERNAME                                           VARCHAR2(30)
 SYSDBA                                             NUMBER
 SYSOPER                                            NUMBER
 SYSASM                                             NUMBER
 VALID                                              NUMBER

Now that the table definitions for the above three x$ tables for the kernel security (KZ) layer are defined, drill down with the following code example to obtain details for Oracle 11g security roles and privileges.

SQL> select username, sysdba, sysoper, sysasm, valid
  2  from x$kzsrt;

USERNAME                     SYSDBA    SYSOPER     SYSASM      VALID
------------------------------ ---------- ---------- ---------- ----
INTERNAL                         1          1          0          1
SYS                              1          1          0          1

The above query against the x$kzsrt table yields details for the Oracle 11g remote password entries for 11g roles including that for SYSDBA, SYSOPER and SYSASM along with a status value for whether the elevated privilege has been enabled or not within the Oracle 11g database. A value of 1 indicates that an account has been enabled for these privileges while a value of 0 would indicate that no user has these privileges enabled in the Oracle database.

A cursory walkthrough of the x$ tables for Oracle 11g has now been provided, so the survey will conclude with how x$ tables can be used by the experienced Oracle professional to investigate and understand Oracle 11g new features.

你可能感兴趣的:(x$ kernel service & cache table tips)