[20210603]如何跟蹤索引分裂.txt
[20210603]如何跟蹤索引分裂.txt
--//oracle索引分裂有兩種:50-50,90-10.一些測試需要要跟蹤索引的分裂?應該以前也做過類似測試.
1.環境:
SCOTT@book> @ &&r/ver1
PORT_STRING VERSION BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx 11.2.0.4.0 Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
SYS@book> select name from v$sysstat where name like '%split%' order by name;
NAME
--------------------
branch node splits
leaf node 90-10 splits
leaf node splits
queue splits
root node splits
$ oerr ora 10224
10224, 00000, "index block split/delete trace"
// *Cause:
// *Action:
--//很明顯跟蹤索引分裂使用10224事件.
2.測試:
drop table t1 purge;
create table t1 ( id number ,name varchar2(100)) ;
create index i_t1_id on t1(id);
alter session set events '10224 trace name context forever,level 1';
insert into t1 select rownum,lpad('a',100,rownum) from dual connect by level<=541;
commit;
--//跟蹤內容如下:
*** 2021-06-04 08:39:50.559
*** SESSION ID:(295.5) 2021-06-04 08:39:50.559
*** CLIENT ID:() 2021-06-04 08:39:50.559
*** SERVICE NAME:(SYS$USERS) 2021-06-04 08:39:50.559
*** MODULE NAME:(SQL*Plus) 2021-06-04 08:39:50.559
*** ACTION NAME:() 2021-06-04 08:39:50.559
splitting leaf,dba 0x010002b3,time 08:39:50.558
kdisnew_bseg_srch_cbk reject block -mark full,dba 0x010002b3,time 08:39:50.559
kdisnew_bseg_srch_cbk rejecting block ,dba 0x010002b3,time 08:39:50.559
kdisnew_bseg_srch_cbk using block,dba 0x010002b5,time 08:39:50.559
kdisnew_bseg_srch_cbk reject block -mark full,dba 0x010002b5,time 08:39:50.560
kdisnew_bseg_srch_cbk rejecting block ,dba 0x010002b5,time 08:39:50.560
kdisnew_bseg_srch_cbk using block,dba 0x010002b6,time 08:39:50.560
--//0x010002b3 = set dba 4,691 = alter system dump datafile 4 block 691 = 16777907
--//0x010002b5 = set dba 4,693 = alter system dump datafile 4 block 693 = 16777909
--//0x010002b6 = set dba 4,694 = alter system dump datafile 4 block 694 = 16777910
--//僅僅知道發生了分裂,到底在插入什麼值時發生分裂還是不知道.
SCOTT@book> select HEADER_FILE,HEADER_BLOCK from dba_segments where segment_name='I_T1_ID';
HEADER_FILE HEADER_BLOCK
----------- ------------
4 690
--//說明dba=4,691是索引的根節點.
SCOTT@book> @ treedump.sql i_t1_id
OBJECT_ID
----------
92867
Session altered.
--//跟蹤檔案內容如下:
----- begin tree dump
branch: 0x10002b3 16777907 (0: nrow: 2, level: 1)
leaf: 0x10002b5 16777909 (-1: nrow: 540 rrow: 540)
leaf: 0x10002b6 16777910 (0: nrow: 1 rrow: 1)
----- end tree dump
--//結合索引塊的儲存,想象一下索引分裂的過程.
--//首先發現dba 0x010002b3塊 -mark full ,reject block ,rejecting block dba 0x010002b3。
--//索引分裂,using block,dba 0x010002b5,發現dba 0x010002b5 塊-mark full,reject block,rejecting block dba 0x010002b5。
--//最後使用dba 0x10002b6。
3.繼續做一個50-50分裂的情況:
drop table t1 purge;
create table t1 ( id number ,name varchar2(100)) ;
create index i_t1_id on t1(id);
alter session set events '10224 trace name context forever,level 1';
insert into t1 select rownum,lpad('a',100,rownum) from dual connect by level<=540;
commit;
insert into t1 values (100,lpad('b',100,'b'));
commit;
--//跟蹤內容如下:
*** TRACE CONTINUED FROM FILE /u01/app/oracle/diag/rdbms/book/book/trace/book_ora_44887_0002.trc ***
splitting leaf,dba 0x010002b3,time 08:47:32.912
kdisnew_bseg_srch_cbk reject block -mark full,dba 0x010002b3,time 08:47:32.913
kdisnew_bseg_srch_cbk rejecting block ,dba 0x010002b3,time 08:47:32.913
kdisnew_bseg_srch_cbk using block,dba 0x010002b5,time 08:47:32.914
kdisnew_bseg_srch_cbk reject block -mark full,dba 0x010002b5,time 08:47:32.914
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
kdisnew_bseg_srch_cbk rejecting block ,dba 0x010002b5,time 08:47:32.914
kdisnew_bseg_srch_cbk using block,dba 0x010002b6,time 08:47:32.914
--//有點奇怪的下劃線的內容,不應該提示-mark full,而是鍵值400這個值無法插入這個塊。
--//也許這種情況也是當作mark full處理。
SCOTT@book> @ treedump.sql i_t1_id
OBJECT_ID
----------
92869
Session altered.
*** 2021-06-04 08:48:06.777
----- begin tree dump
branch: 0x10002b3 16777907 (0: nrow: 2, level: 1)
leaf: 0x10002b5 16777909 (-1: nrow: 279 rrow: 279)
leaf: 0x10002b6 16777910 (0: nrow: 262 rrow: 262)
----- end tree dump
--//出現50-50分裂。
4.附上執行指令碼:
$ cat treedump.sql
column object_id new_value m_index_id
select object_id from user_objects where object_name = upper('&&1') and object_type = 'INDEX';
alter session set events 'immediate trace name treedump level &m_index_id';
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2775393/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- [20210604]索引分裂與 itl ktbitflg.txt索引
- [20211105]索引分裂 塊清除 日誌增加.txt索引
- [20211105]索引分裂塊清除日誌增加(唯一索引).txt索引
- [20190402]跟蹤vmstat.txt
- [20211108]索引分裂塊清除日誌增加(唯一索引)2.txt索引
- [20231025]跟蹤rename操作2.txt
- [20190401]跟蹤dbms_lock.sleep呼叫.txt
- [20211013]閱讀ldd原始碼跟蹤.txt原始碼
- [20190917]oracle跟蹤事件簡單寫法.txtOracle事件
- [20210220]gdb跟蹤邏輯讀2.txt
- [20200818]12c 10046跟蹤時間戳.txt時間戳
- [20210401]跟蹤sqlplus登入執行了什麼.txtSQL
- [20200219]strace跟蹤設定ENABLE=BROKEN的情況.txt
- [20200326]dbms_monitor跟蹤與SQL語句分析.txtSQL
- [20211011]跟蹤freespace空間的變化情況.txt
- [20191221]12c查詢跟蹤檔案內容.txt
- [20200818]12c 10046跟蹤時間戳2.txt時間戳
- [20240920]跟蹤library cache lock library cache pin使用gdb.txt
- [20240824]跟蹤library cache lock library cache pin使用gdb.txt
- IDEA之如何Debug原始碼跟蹤Idea原始碼
- 如何使用iPhone限制IP地址跟蹤iPhone
- 資料庫索引分裂 問題分析資料庫索引
- [20211227]抽取跟蹤檔案中的繫結變數值.txt變數
- Oracle索引塊分裂split資訊彙總Oracle索引
- [20200417]跟蹤特定sql語句以及v$open_cursor檢視.txtSQL
- 如何分配和跟蹤專案工作量?
- 如何在 Git 中取消檔案的跟蹤Git
- 如何實現Dolphinscheduler YARN Task狀態跟蹤?Yarn
- sp_trace_setfilter sqlserver篩選跟蹤或跟蹤過濾FilterSQLServer
- [20201118]18c 10046跟蹤時間戳3(虛擬機器).txt時間戳虛擬機
- 主力跟蹤戰法
- 反跟蹤技術
- git的跟蹤分支和遠端跟蹤分支學習筆記Git筆記
- [20210317]如何知道索引塊地址2.txt索引
- ORACLE 12c索引分裂引起的會話夯Oracle索引會話
- [20200219]strace跟蹤設定ENABLE=BROKEN的情況(網路的情況).txt
- [20200422]跟蹤特定sql語句以及v$open_cursor檢視(補充).txtSQL
- [20200417]跟蹤特定sql語句以及v$open_cursor檢視2.txtSQL