PCTFREE, PCTUSED, INITRANS, MAXTRANS, FREELIST PARAMETERS

PCTFREE, PCTUSED

PCTFREE参数用于指定块中必须保留的最小空闲空间比例.之所以要为块保留一些空闲空间,是因为在对块中存储的数据进行修改时(UPDATE操作),有可能会需要更多的存储空间.这时如果块中存储空间不足,就必须分配新块,此时会产生指针,降低性能.而如果每块在最初填写数据时均不填满,保留一部分可用空间,比如20%,则可以尽量避免上述问题.

PCTUSED参数用于指定一个百分比,当块中已经使用的存储空间降低到这个百分比之下时,这个块才被标记为可用.

要形容一个 BLOCK 的运作,我们可以把一个 BLOCK 想成一个水杯。侍者把水倒入放在我们面前的水杯,要多满呢,我们要求他倒 9 分满好了,这时候 PCTFREE 代表着设定为 10 ,意思就是说,当 BLOCK 使用到达 90% 的时候,就不可以在使用了,这个 BLOCK 应该从 FREELIST 列表中移除 (un-link) 。为何要保留 10% 的空间呢?这是为了提供 update 数据时所可能增加的空间使用,如果空间保留的太小,就容易发生 row chaining 。

PCTUSED 代表着这杯水什么时候可以添加,假设 PCTUSED 为 40 ,代表当我们把水杯的水喝到剩下 40% 以下时,侍者就会知道需要加水了。你想想看,如果说在餐厅里妳每喝一口水侍者就来加水,你会不会觉得很烦,对餐厅来说,也要派很多人不断帮每桌客人加水,这生意还能做吗?所以说, PCTUSED 代表着 re-link 回 FREELIST 的意义,如果说 PCTUSED 设的太大,例如 70 好了,代表这杯水你随便喝一口侍者就要来加水了,这隐含的意义是,这个杯子的利用率增加,但是侍者频繁的服务造成了负荷 (I/O Overhead) 。 PCTUSED 设小一点,例如 10 ,代表当水喝到剩下 10% 的时候 ( 如同 DELETE 事务操作 ) ,才须要放回 FREELIST ,代表可以加水了 ( 如同 INSERT 事务操作 ) 。

简单的说,如果要经常性的UPDATE操作,PCTFREE就要设得大一些,反之就设小一些;如果希望储存空间发挥最大使用效益,可以把PCTUSED设大一点,相反的,如果想要提高IO效能,应该把PCTUSED设定小一点。

针对不同情况,有如下两种参考设置:

1、高PCTFREE,低PCTUSED,用于插入许多将要更新的数据,并且更新经常会增加行的大小,这样插入后在块上保留了许多空间(高PCTFREE),在块返回到自由列表之前,块必须是空的(低PCTUSED);

2、低PCTFREE,高PCTUSED,用于倾向于对表只使用INSERT和DELETE,或者如果要UPDATE,UPDATE也只是会使行变小。

FREELIST

FREELIST 储存着可使用的 BLOCK 信息,当 BLOCK 被 DELETE 数据使用量下降到 PCTUSED 时,就会重新放置到 FREELIST 上,让其它新增数据使用。一个对象可能不止有一个FreeList,如果预料会有许多并行用户对一个对象进行大量插入和更新操作,配置多个FreeList能提高整体性能,拥有足够的FreeList供使用是很关键的,能极大提高性能,其代价是增加存储空间。FREELIST 存放在 TABLE/INDEX 的 Segment Header 中,他管理着所有可以新增数据的 BLOCK 信息。依照 TABLE 使用的需求调整 FREELIST 的数量也是 IO Tuning 的一个重点。

INITRANS, MAXTRANX

对象中的每一个块都有一个块头,块头的一部分是事务表,事务表中的条目描述哪一个事务块上的行或元素被锁定了,事务块的最初大小由INITRANS设置,默认2,当需要时,事务表可以动态增加,大小最多到MAXTRANS(假定块上有足够的空闲空间),每一个分配的事务条目在块头上占用23字节的存储空间。

INITRANS 指的是一个 BLOCK 上初始预分配给并行交易控制的空间 (ITLs), 简单的说就是一个块上能有几个active transaction。

( 当 BLOCK 上某笔 ROW 被交易更新锁定时,会在 BLOCK header ITL allocate 一个锁,当下一个交易要更新同一笔 row 时,就会发现他已经被先前的交易持有锁了,会先去检查该交易是否 active? 如果是,后来的该笔交易就会被 blocking ,等待 ) 如果一个表格需要同时有大量交易存取,应该设定 INITRANS 大一点,可以减少 ITL 还要动态扩充的 Overhead 。

MAXTRANS 指的是如果 INITRANS 空间不够用了,就会自动扩展 ITL ,直到最大值也就是 MAXTRANS 值为止,预设是 255 。但是,如果 BLOCK 空间已经不足,也有可能无法持续扩充到 255 个 ITL 空间喔。

ITL-interested transaction list

itl的全称是interested transaction list,是oracle中事物处理的关键组件。itl由xid,uba,flag,lck和scn/fsc组成。其最小值为1,由参数initrans控制(由于兼容性的原因,oracle会在对象的存储块分配两个itl,所以initrans的最小值实际上为2),最大值为255,由参数maxtrans控制,itl是block级的概念,一个itl占用块46B的空间,参数initrans意味着块中除去block header外一部分存储空间无法被记录使用(46B*initrans),当块中还有一定的free space时,oracle可以使用free space构建itl供事物使用,直到块中没有足够数量的free space或者块中实际的itl数量超过maxtrans。maxtrans和initrans可以使用alter语句进行修改,maxtrans参数的修改会对所有块生效,initrans参数的修改只对没有数据的块生效。

你可能感兴趣的:(CSDN/nsj820迁移,Oracle,数据库,oracle)