Chinaunix首页 | 论坛 | 博客
  • 博客访问: 366068
  • 博文数量: 79
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 42
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-30 12:25
文章分类

全部博文(79)

文章存档

2019年(1)

2017年(19)

2016年(25)

2015年(30)

2014年(4)

分类: Oracle

2016-09-05 20:48:41

当数据块没有足够的空间来分配ITL事务槽的时候,那么事务将会处于enq: TX - allocate ITL entry等待中。

本文进行一个简单的模拟。

SQL> create table t(x int,y varchar2(200)) pctfree 0 initrans 1;

Table created.

SQL> insert into t select rownum,object_name from all_objects where rownum<=1000;

1000 rows created.

SQL> commit;

Commit complete.


SQL> desc t;
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 X                                                  NUMBER(38)
 Y                                                  VARCHAR2(200)

SQL> select distinct dbms_rowid.rowid_relative_fno(rowid),dbms_rowid.rowid_block_number(rowid) from t;


DBMS_ROWID.ROWID_RELATIVE_FNO(ROWID) DBMS_ROWID.ROWID_BLOCK_NUMBER(ROWID)
------------------------------------ ------------------------------------
                                   5                               681445
                                   5                               681448
                                   5                               681446
                                   5                               681444



选取BLOCK 681444作为测试块。

SQL> alter system dump datafile 5 block 681444;

System altered.

SQL> oradebug setmypid
Statement processed.
SQL> oradebug tracefile_name
/u01/oracle/admin/testb/udump/testb2_ora_464334.trc


Block header dump:  0x014a65e4
 Object id on Block? Y
 seg/obj: 0xa7f65c  csc: 0x83e.7d87ebd2  itc: 2  flg: E  typ: 1 - DATA
     brn: 0  bdba: 0x14a65e1 ver: 0x01 opc: 0
     inc: 0  exflg: 0
 
 Itl           Xid                  Uba         Flag  Lck        Scn/Fsc
0x01   0x0011.009.0004de5b  0xc9c0047f.2ca1.13  --U-  305  fsc 0x0000.7d87ebd3
0x02   0x0000.000.00000000  0x00000000.0000.00  ----    0  fsc 0x0000.00000000
 
data_block_dump,data header at 0x110444064
===============
tsiz: 0x1f98
hsiz: 0x274
pbl: 0x110444064
bdba: 0x014a65e4
     76543210
flag=--------
ntab=1
nrow=305
frre=-1
fsbo=0x274
fseo=0x284
avsp=0x10
tosp=0x10


从上面可以看出上面的BLOCK 681444中只有2个ITL,而且剩余的自由空间为fseo-fsbo==0x284-0x274=0x10 

而分配一个ITL需要24BYTE,因此这个数据块最大只能支持2个事务。


SQL> select x
  2    from (select x, y, dbms_rowid.rowid_block_number(rowid) block# from t)
  3   where block# = 681444 and rownum<=4;

         X
----------
       319
       320
       321
       322

通过上面查询可以知道记录319,320,321都在块681444中。

SESSION 1:

SQL> update t set y=y where x=319;

1 row updated.


SESSION 2:

SQL> update t set y=y where x=320;

1 row updated.

SESSION 3:

SQL> update scott.t set y=y where x=321;

将会HANG住。


通过下面的查询可以看到有1个会话处于ITL等待中:


SQL>  select event from v$session where  event like 'enq%';

EVENT
--------------------------------------------------------------------------------
enq: TX - allocate ITL entry


SESSION 4:

SQL> update t set y=y where x=321;

将会HANG住。


在此运行select event from v$session where  event like 'enq%' 将会看到2个会话处于enq: TX - allocate ITL entry等待中。

SQL>  select event from v$session where  event like 'enq%';

EVENT
--------------------------------------------------------------------------------
enq: TX - allocate ITL entry

SQL> /

EVENT
--------------------------------------------------------------------------------
enq: TX - allocate ITL entry
enq: TX - allocate ITL entry

阅读(930) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~